python 中join()函数strip() 函数和 split() 函数的详解及实例

1、join()函数

Python中有join()和os.path.join()两个函数,具体作用如下:

join(): 连接字符串数组。将字符串、元组、列表中的元素以指定的字符(分隔符)连接生成一个新的字符串

语法: ‘sep’.join(seq)

参数说明
sep:分隔符。可以为空
seq:要连接的元素序列、字符串、元组、字典
上面的语法即:以sep作为分隔符,将seq所有的元素合并成一个新的字符串

返回值:返回一个以分隔符sep连接各个元素后生成的字符串

os.path.join(): 将多个路径组合后返回

语法: os.path.join(path1[,path2[,…]])

返回值:将多个路径组合后返回

注:第一个绝对路径之前的参数将被忽略

#对序列进行操作(分别使用' '与':'作为分隔符)
  
>>> seq1 = ['hello','good','boy','doiido']
>>> print ' '.join(seq1)
hello good boy doiido
>>> print ':'.join(seq1)
hello:good:boy:doiido
  
  
#对字符串进行操作
  
>>> seq2 = "hello good boy doiido"
>>> print ':'.join(seq2)
h:e:l:l:o: :g:o:o:d: :b:o:y: :d:o:i:i:d:o
  
  
#对元组进行操作
  
>>> seq3 = ('hello','good','boy','doiido')
>>> print ':'.join(seq3)
hello:good:boy:doiido
  
  
#对字典进行操作
  
>>> seq4 = {'hello':1,'good':2,'boy':3,'doiido':4}
>>> print ':'.join(seq4)
boy:good:doiido:hello
  
  
#合并目录
  
>>> import os
>>> os.path.join('/hello/','good/boy/','doiido')
'/hello/good/boy/doiido'

2,Python strip()函数 介绍

函数原型

声明:s为字符串,rm为要删除的字符序列

s.strip(rm) 删除s字符串中开头、结尾处,位于 rm删除序列的字符

s.lstrip(rm) 删除s字符串中开头处,位于 rm删除序列的字符

s.rstrip(rm) 删除s字符串中结尾处,位于 rm删除序列的字符

注意:

(1)当rm为空时,默认删除空白符(包括’\n’, ‘\r’, ‘\t’, ’ ')

(2)这里的rm删除序列是只要边(开头或结尾)上的字符在删除序列内,就删除掉。

例如,

a = ’ 123’
a
’ 123’
a.strip()
‘123’

(2)这里的rm删除序列是只要边(开头或结尾)上的字符在删除序列内,就删除掉。

例如,

a = ‘123abc’
a.strip(‘21’)
‘3abc’
a.strip(‘12’)
‘3abc’

3, python split()函数 介绍

说明:

Python中没有字符类型的说法,只有字符串,这里所说的字符就是只包含一个字符的字符串!!!

这里这样写的原因只是为了方便理解,仅此而已。

(1)按某一个字符分割,如‘.’

str = (‘www.google.com’)
print str
www.google.com
str_split = str.split(’.’)
print str_split
[‘www’, ‘google’, ‘com’]
(2)按某一个字符分割,且分割n次。如按‘.'分割1次

str_split = str.split(’.’,1)
print str_split
[‘www’, ‘google.com’]
(3)split()函数后面还可以加正则表达式,例如:

str_split = str.split(’.’)[0]
print str_split
www
split分隔后是一个列表,[0]表示取其第一个元素;

str_split = str.split(’.’)[::-1]
print str_split
[‘com’, ‘google’, ‘www’]
str_split = str.split(’.’)[::]
print str_split
[‘www’, ‘google’, ‘com’]
按反序列排列,[::]安正序排列

str = str + ‘.com.cn’
str
www.google.com.com.cn
str_split = str.split(’.’)[::-1]
print str_split
[‘cn’, ‘com’, ‘com’, ‘google’, ‘www’]
str_split = str.split(’.’)[:-1]
print str_split
[‘www’, ‘google’, ‘com’, ‘com’]
从首个元素开始到次末尾,最后一个元素删除掉。

split()函数典型应用之一,ip数字互换:

ip ==> 数字

ip2num = lambda x:sum([256**j*int(i) for j,i in enumerate(x.split(’.’)[::-1])])
ip2num(‘192.168.0.1’)
3232235521

数字 ==> ip # 数字范围[0, 255^4]

num2ip = lambda x: ‘.’.join([str(x/(256**i)%256) for i in range(3,-1,-1)])
num2ip(3232235521)
‘192.168.0.1’
最后,python怎样将一个整数与IP地址相互转换?
import socket
import struct
int_ip = 123456789
socket.inet_ntoa(struct.pack(‘I’,socket.htonl(int_ip)))#整数转换为ip地址
‘7.91.205.21’
str(socket.ntohl(struct.unpack(“I”,socket.inet_aton(“255.255.255.255″))[0]))#ip地址转换为整数
‘4294967295’

猜你喜欢

转载自blog.csdn.net/work_you_will_see/article/details/84636115