Python 拆分字符串


数:split()

Python中有split()和os.path.split()两个函数,具体作用如下:
split():拆分字符串。通过指定分隔符对字符串进行切片,并返回分割后的字符串列表(list)
os.path.split():按照路径将文件名和路径分割开

一、函数说明
1、split()函数
语法:str.split(str="",num=string.count(str))[n]

参数说明:
str:   表示为分隔符,默认为空格,但是不能为空('')。若字符串中没有分隔符,则把整个字符串作为列表的一个元素
num:表示分割次数。如果存在参数num,则仅分隔成 num+1 个子字符串,并且每一个子字符串可以赋给新的变量
[n]:   表示选取第n个分片

注意:当使用空格作为分隔符时,对于中间为空的项会自动忽略

2、os.path.split()函数
语法:os.path.split('PATH')

参数说明:
PATH指一个文件的全路径作为参数:
如果给出的是一个目录和文件名,则输出路径和文件名
如果给出的是一个目录名,则输出路径和为空文件名


二、实例
1、常用实例

 

?
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
36
37
38
>>> u  = "www.doiido.com.cn"
 
#使用默认分隔符
>>>  print u.split()
[ 'www.doiido.com.cn' ]
 
#以"."为分隔符
>>>  print u.split( '.' )
[ 'www' 'doiido' 'com' 'cn' ]
 
#分割0次
>>>  print u.split( '.' , 0 )
[ 'www.doiido.com.cn' ]
 
#分割一次
>>>  print u.split( '.' , 1 )
[ 'www' 'doiido.com.cn' ]
 
#分割两次
>>>  print u.split( '.' , 2 )
[ 'www' 'doiido' 'com.cn' ]
 
#分割两次,并取序列为1的项
>>>  print u.split( '.' , 2 )[ 1 ]
doiido
 
#分割最多次(实际与不加num参数相同)
>>>  print u.split( '.' , - 1 )
[ 'www' 'doiido' 'com' 'cn' ]
 
#分割两次,并把分割后的三个部分保存到三个文件
>>> u1,u2,u3  = u.split( '.' , 2 )
>>>  print u1
www
>>>  print u2
doiido
>>>  print u3
com.cn

 

2、去掉换行符

?
1
2
3
4
5
6
7
8
9
10
11
>>> c  = '''say
hello
baby'''
 
>>>  print c
say
hello
baby
 
>>>  print c.split( '\n' )
[ 'say' 'hello' 'baby' ]


3、分离文件名和路径

?
1
2
3
4
5
>>>  import os
>>>  print os.path.split( '/dodo/soft/python/' )
( '/dodo/soft/python' , '')
>>>  print os.path.split( '/dodo/soft/python' )
( '/dodo/soft' 'python' )


4、一个超级好的例子

?
1
2
3
4
5
6
7
>>>  str = "hello boy<[www.doiido.com]>byebye"
 
>>>  print str .split( "[" )[ 1 ].split( "]" )[ 0 ]
www.doiido.com
 
>>>  print str .split( "[" )[ 1 ].split( "]" )[ 0 ].split( "." )
[ 'www' 'doiido' 'com' ]

 


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM