python 中join()函数strip() 函数和 split() 函数的详解及实例
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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[,......]])
返回值:将多个路径组合后返回
注:第一个绝对路径之前的参数将被忽略
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 ‘ |
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
以上是关于python 中join()函数strip() 函数和 split() 函数的详解及实例的主要内容,如果未能解决你的问题,请参考以下文章
好好学python · 字符串(find(),index(),split(),join(),strip(),replace())
python字符串的操作(去掉空格strip(),切片,查找,连接join(),分割split(),转换首字母大写, 转换字母大小写...)