split()函數基本格式:
split(sep=None, maxsplit=-1)
返回一個由字符串內單詞組成的列表,使用 sep 作為分隔字符串。
如果給出了 maxsplit,則最多進行 maxsplit 次拆分(因此,列表最多會有 maxsplit+1 個元素)。
如果 maxsplit 未指定或為 -1,則不限制拆分次數(進行所有可能的拆分)。
seq
分隔字符串默認為None,maxsplit
默認表明不限制拆分次數。split()
返回一個list
情形1:給`sep``:依據sep對字符串進行全部拆分
'a.bc'.split('.')
['a', 'bc']
情形2:給sep
,給maxsplit
:依據sep
對字符串按照maxsplit
的值進行拆分
'a.b.c'.split('.',maxsplit=1)
['a', 'b.c']
情形3:如果 sep
未指定或為 None
:連續的空格會被視為單個分隔符,其結果將不包含開頭或末尾的空字符串,如果字符串包含前綴或後綴空格的話。
'1 2 3'.split()
#['1', '2', '3']
'1 2 3'.split(maxsplit=1)
#['1', '2 3']
' 1 2 3 '.split()
#['1', '2', '3']
情形4:處理連續的分隔符:連續的分隔符不會被組合在一起而是被視為分隔空字符串
'a.b..c'.split('.')
['a', 'b', '', 'c']
rsplit()基本格式:
rsplit(sep=None, maxsplit=- 1)
返回一個由字符串內單詞組成的列表,使用 sep 作為分隔字符串。
如果給出了 maxsplit,則最多進行 maxsplit 次拆分,從 最右邊 開始。
與split()函數
的區別:rsplit()
從 最右邊 開始進行拆分rsplit()
其余行為和split()
相同
splitlines()基本格式:
splitlines(keepends=False)
返回由原字符串中各行組成的列表,在行邊界的位置拆分。
結果列表中不包含行邊界,除非給出了 keepends 且為真值。
情形1:默認splitlines()
'ab c\n\nde fg\rkl\r\n'.splitlines()
#['ab c', '', 'de fg', 'kl']
情形2:包含行邊界 keepends = True
'ab c\n\nde fg\rkl\r\n'.splitlines(keepends=True)
#['ab c\n', '\n', 'de fg\r', 'kl\r\n']
當給出了分隔字符串 sep
時,對於空字符串此方法將返回一個空列表;末尾的換行不會令結果中增加額外的行.
"".splitlines()
#[]
"One line\n".splitlines()
#['One line']
作為比較,split('\n')
的結果為:
''.split('\n')
#['']
'Two lines\n'.split('\n')
#['Two lines', '']
內置類型-split:https://docs.python.org/zh-cn/3/library/stdtypes.html?highlight=split