一、關於split 和 join 方法
1只針對字串進行處理。split:拆分字串、join連線字串
2.string.join(sep): 以string作為分割符,將sep中所有的元素(字串表示)合併成一個新的字串
3.string.split(str=' ',num=string.count(str)): 以str為分隔,符切片string,如果num有指定值,則僅分隔num個子字串。
4.對匯入os模組進行os.path.splie()/os.path.join() 貌似是處理機制不一樣,但是功能上一樣。
二、split()方法
help後的資訊如下:
split(…)
S.split([sep [,maxsplit]]) -> list of strings
Return a list of the words in the string S, using sep as the
delimiter string. If maxsplit is given, at most maxsplit
splits are done. If sep is not specified or is None, any
whitespace string is a separator.
中文翻譯:
split(…)
S.split([sep [,maxsplit]]) -> 由字串分割成的列表
返回一組使用分隔符(sep)分割字串形成的列表。如果指定最大分割數,則在最大分割時結束。如果分隔符未指定或者為none,則分隔符預設為空格。
例項:
s='a b c' print s.split(' ') st='hello world' print st.split('o') print st.split('o',1) --------output--------- ['a', 'b', 'c'] ['hell', ' w', 'rld'] ['hell', ' world'] os.path.split()
os.path.split是按照路徑將檔名和路徑分割開,比如d:\\python\\python.ext,可分割為['d:\\python', 'python.exe'],示例如下:
import os print os.path.split('c:\\Program File\\123.doc') print os.path.split('c:\\Program File\\') -----------------output--------------------- ('c:\\Program File', '123.doc') ('c:\\Program File', '')
三、join()
a='abcd' print '.'.join(a) print '|'.join(['a','b','c']) #可以把['a','b','c']看做是 a='abcd';下面同理 print '.'.join({'a':1,'b':2,'c':3,'d':4})
注意:'.'等做分隔符,將join裡的所有元素(字串)透過分隔符連線成一個新的字串
可能有人像我一樣咬文嚼字,針對string.join()的定義愛鑽牛角尖,硬生生地將['a','b','c']先轉換為字串,然後在join
如:
b=str(['a','b','c'])
print '|'.join(b)
我以為這樣是正解,但是不然。輸出結果是:[|'|a|'|,| |'|b|'|,| |'|c|'|],而導致與上面不一致的原因就是畫蛇添足了,把['a','b','c']轉換成了字串,在Python中,我們發現字串、元祖、列表它們是序列型別,有著相同的訪問方式,可以以下標來訪問其中的元素。
以上可以再敲一遍試試。
輸入:
輸出:
a.b.c.d
a|b|c
a.c.b.d
os.path.join(path1[,path2[,......]])
os.path.join(path1[, path2[, ...]]) #將多個路徑組合後返回,第一個絕對路徑之前的引數將被忽略。 >>> os.path.join('c:\\', 'csv', 'test.csv') 'c:\\csv\\test.csv' >>> os.path.join('windows\temp', 'c:\\', 'csv', 'test.csv') 'c:\\csv\\test.csv' >>> os.path.join('/home/aa','/home/aa/bb','/home/aa/bb/c') '/home/aa/bb/c'