使用 str.splitlines()
方法逐行读取多行字符串,例如 for line in multiline_str.splitlines():
。str.splitlines()
方法在每个换行符处拆分字符串并返回字符串中的行列表。
multiline_str = """\
First line
Second line
Third line"""
# First line
# Second line
# Third line
for line in multiline_str.splitlines():
print(line)
str.splitlines()
方法将字符串拆分为换行符,并返回一个包含字符串中行的列表。
multiline_str = """\
First line
Second line
Third line"""
lines = multiline_str.splitlines()
print(lines) # ️ ['First line', 'Second line', 'Third line']
除非 keepends
参数设置为 True,否则该方法不包括换行符。
multiline_str = """\
First line
Second line
Third line"""
lines = multiline_str.splitlines(True)
print(lines) # ️ ['First line\n', 'Second line\n', 'Third line']
str.splitlines()
方法在不同的行边界上拆分,例如\n
、\r
、\r\n
等
my_str = "one\rtwo\r\nthree\n"
lines = my_str.splitlines()
print(lines) # ️ ['one', 'two', 'three']
如果字符串以换行符结尾,则 splitlines()
方法将其删除,而不是 str.split()
方法。
my_str = "one\ntwo\nthree\n"
lines = my_str.splitlines()
print(lines) # ️ ['one', 'two', 'three']
lines = my_str.split('\n')
print(lines) # ️ ['one', 'two', 'three', '']
请注意
,str.split()
方法返回的列表中的最后一项是空字符串。
使用
str.splitlines()
获取字符串中的行列表后,使用 for 循环遍历列表并逐行读取。
再看下面的例子。
multiline_str = """\
First line
Second line
Third line"""
# First line
# Second line
# Third line
for line in multiline_str.splitlines():
print(line)
如果文本和换行符之间有空格,请使用 str.strip()
方法将其删除。
my_str = 'one \ntwo \n three \n'
# ️ ['one ', 'two ', ' three ']
print(my_str.splitlines())
lines = [line.strip() for line in my_str.splitlines()]
print(lines) # ️ ['one', 'two', 'three']
我们使用列表推导来迭代列表。
列表推导用于对每个元素执行一些操作,或者选择满足条件的元素子集。
在每次迭代中,我们调用
str.strip()
方法从字符串中删除任何前导和尾随空格。
如果我们在结果中得到空字符串并想要过滤掉它们,请使用 filter()
函数。
my_str = '\rone\r\ntwo\nthree\n'
# ️ ['', 'one', 'two', 'three']
print(my_str.splitlines())
lines = list(filter(None, my_str.splitlines()))
# one
# two
# three
for line in lines:
print(line)
filter()
函数将一个函数和一个迭代器作为参数,并从迭代器的元素构造一个迭代器,函数为其返回一个真值。
如果为函数参数传递
None
,则可迭代的所有虚假元素都将被删除。
空字符串是虚假值,因此空字符串列表项已从列表中删除。