1、join()函数
Python中有join()和os.path.join()两个函数,具体作用如下:
join(): 连接字符串数组。将字符串、元组、列表中的元素以指定的字符(分隔符)连接生成一个新的字符串
语法: ‘sep‘.join(seq)
参数说明
sep:分隔符。可以为空
seq:要连接的元素序列、字符串、元组、字典
上面的语法即:以sep作为分隔符,将seq所有的元素合并成一个新的字符串
返回值:返回一个以分隔符sep连接各个元素后生成的字符串
os.path.join(): 将多个路径组合后返回
语法: os.path.join(path1[,path2[,......]])
返回值:将多个路径组合后返回
注:第一个绝对路径之前的参数将被忽略
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
|
#对序列进行操作(分别使用‘ ‘与‘:‘作为分隔符)
>>> 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删除序列是只要边(开头或结尾)上的字符在删除序列内,就删除掉。
例如,
1
2
3
4
5
|
>>> a = ‘ 123‘
>>> a
‘ 123‘
>>> a.strip()
‘123‘
|
(2)这里的rm删除序列是只要边(开头或结尾)上的字符在删除序列内,就删除掉。
例如,
1
2
3
4
5
|
>>> a = ‘123abc‘
>>> a.strip( ‘21‘ )
‘3abc‘
>>> a.strip( ‘12‘ )
‘3abc‘
|
结果是一样的。
3, python split()函数 介绍
说明:
Python中没有字符类型的说法,只有字符串,这里所说的字符就是只包含一个字符的字符串!!!
这里这样写的原因只是为了方便理解,仅此而已。
(1)按某一个字符分割,如‘.‘
1
2
3
4
5
6
|
>>> str = ( ‘www.google.com‘ )
>>> print str
www.google.com
>>> str_split = str .split( ‘.‘ )
>>> print str_split
[ ‘www‘ , ‘google‘ , ‘com‘ ]
|
(2)按某一个字符分割,且分割n次。如按‘.‘分割1次
1
2
3
|
>>> str_split = str .split( ‘.‘ , 1 )
>>> print str_split
[ ‘www‘ , ‘google.com‘ ]
|
(3)split()函数后面还可以加正则表达式,例如:
1
2
3
|
>>> str_split = str .split( ‘.‘ )[ 0 ]
>>> print str_split
www
|
split分隔后是一个列表,[0]表示取其第一个元素;
1
2
3
4
5
6
|
>>> str_split = str .split( ‘.‘ )[:: - 1 ]
>>> print str_split
[ ‘com‘ , ‘google‘ , ‘www‘ ]
>>> str_split = str .split( ‘.‘ )[::]
>>> print str_split
[ ‘www‘ , ‘google‘ , ‘com‘ ]
|
按反序列排列,[::]安正序排列
1
2
3
4
5
6
7
8
9
|
>>> 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 ==> 数字
1
2
3
|
>>> 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]
1
2
3
|
>>> num2ip = lambda x: ‘.‘ .join([ str (x / ( 256 * * i) % 256 ) for i in range ( 3 , - 1 , - 1 )])
>>> num2ip( 3232235521 )
‘192.168.0.1‘
|
最后,python怎样将一个整数与IP地址相互转换?
1
2
3
4
5
6
7
|
>>> 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 ‘
|
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
时间: 2024-11-04 10:18:26