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 strwww.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‘ |
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
python 中join()函数strip() 函数和 split() 函数的详解及实例
原文:http://www.cnblogs.com/guoy/p/7163705.html