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