Answers:
str.splitlines
方法应该为您提供确切的信息。
>>> data = """a,b,c
... d,e,f
... g,h,i
... j,k,l"""
>>> data.splitlines()
['a,b,c', 'd,e,f', 'g,h,i', 'j,k,l']
str.splitlines
是,\n
如果存在决赛,它将删除决赛。即,'foo\nbar\n'.split() == ['foo', 'bar', '']
而str.splitlines('foo\nbar\n') == ['foo', 'bar']
data = """a,b,c
d,e,f
g,h,i
j,k,l"""
print(data.split()) # ['a,b,c', 'd,e,f', 'g,h,i', 'j,k,l']
str.split
,默认情况下,按所有空白字符分割。如果实际的字符串还有其他空格字符,则可能要使用
print(data.split("\n")) # ['a,b,c', 'd,e,f', 'g,h,i', 'j,k,l']
或者按照评论中的@Ashwini Chaudhary的建议,可以使用
print(data.splitlines())
.splitlines
,如果字符串中有空格等,该怎么办?
split("\n")
。是splitlines
不是更好.split("\n")
?
\r\n
其他类型的线边界。
\n
,splitlines()
则将其忽略,而结果的末尾split("\n")
将有一个空字符串""
。
如果只想用换行符分割,最好使用splitlines():
例:
>>> data = """a,b,c
... d,e,f
... g,h,i
... j,k,l"""
>>> data
'a,b,c\nd,e,f\ng,h,i\nj,k,l'
>>> data.splitlines()
['a,b,c', 'd,e,f', 'g,h,i', 'j,k,l']
使用split()它也可以:
>>> data = """a,b,c
... d,e,f
... g,h,i
... j,k,l"""
>>> data
'a,b,c\nd,e,f\ng,h,i\nj,k,l'
>>> data.split()
['a,b,c', 'd,e,f', 'g,h,i', 'j,k,l']
然而:
>>> data = """
... a, eqw, qwe
... v, ewr, err
... """
>>> data
'\na, eqw, qwe\nv, ewr, err\n'
>>> data.split()
['a,', 'eqw,', 'qwe', 'v,', 'ewr,', 'err']
干得好:
>>> data = """a,b,c
d,e,f
g,h,i
j,k,l"""
>>> data.split() # split automatically splits through \n and space
['a,b,c', 'd,e,f', 'g,h,i', 'j,k,l']
>>>
repr(data)
什么?