Python中有split()和os.path.split()兩個函數:
split():拆分字串。通過指定分隔字元對字串進行切片,並返回分割後的字串列表。
os.path.split():將檔案名稱和路徑分割開。
1、split()函數
文法:str.split(str=" ",num=string.count(str))[n]
參數說明:
str: 表示為分隔字元,預設為空白格,但是不可為空串。若字串中沒有分隔字元,則把整個字串作為列表的一個元素。
num:表示分割次數。如果存在參數num,則僅分隔成 num+1 個子字串。
[n]: 表示選取第n個分區(從0計數)
預設情況下,使用空格作為分隔字元,則分隔後,空串會自動忽略,如:
>>> s='love python'
>>> s.split()
['love', 'python']
但若顯式指定空格為分隔字元,則不會自動忽略空串,如:
>>> s.split(' ')
['love', '', '', '', 'python']
預設的分隔字元除了空格,還有 '\n\t\r',分隔後,空串會自動忽略,如下:
>>> s='love \n\t\r \t\r\n python \n\t\r'
>>> s.split()
['love', 'python']
>>> s='www.pku.edu.cn'
>>> s.split() #預設空格作為分隔字元,但字串中沒有分隔字元,因此,把整個字串作為列表的一個元素
['www.pku.edu.cn']
>>> s.split('.') #以'.'作為分隔字元,沒有指定分隔次數,則有多少 '.' 就分隔多少次
['www', 'pku', 'edu', 'cn']
>>> s.split('.',0) #分隔0次
['www.pku.edu.cn']
>>> s.split('.',1) #分隔1次
['www', 'pku.edu.cn']
>>> s.split('.',2)#分隔2次
['www', 'pku', 'edu.cn']
>>> s.split('.',2)[1]#分隔2次,取索引為1的項
'pku'
>>> s.split('.',-1) #儘可能多的分隔,與不加num參數相同
['www', 'pku', 'edu', 'cn']
>>> s1,s2=s.split('.',1)#分隔1次,並把分隔後的2個字串存放在s1和s2中
>>> s1
'www'
>>> s2
'pku.edu.cn'
>>> s='''love
... hello
... python'''
>>> s
'love\nhello\npython'
>>> s.split('\n')#以'\n'作為分隔字元,分隔次數儘可能的多
['love', 'hello', 'python']
>>> print s
love
hello
python
練習一下下面的例子:
>>> s='hello python<[www.python.com]>hello python'
>>> s.split('[')[1].split(']')[0]
'www.python.com'
>>> s.split('[')[1].split(']')[0].split('.')
['www', 'python', 'com']
2、os.path.split()函數
文法:os.path.split('PATH')
參數說明: PATH指一個檔案的全路徑作為參數: 如果給出的是一個目錄和檔案名稱,則輸出路徑和檔案名稱 如果給出的是一個目錄名,則輸出路徑和為空白檔案名稱 實際上,該函數的分割並不智能,它僅僅是以 "PATH" 中最後一個 '/' 作為分隔字元,分隔後,將索引為0的視為目錄(路徑),將索引為1的視為檔案名稱,如:
>>> import os
>>> os.path.split('C:/soft/python/test.py')
('C:/soft/python', 'test.py')
>>> os.path.split('C:/soft/python/test')
('C:/soft/python', 'test')
>>> os.path.split('C:/soft/python/')
('C:/soft/python', '')
(完)