我想去掉列表中的特殊字符:
file_stuff
['John Smith\n', '\n', 'Gardener\n', '\n', 'Age 27\n', '\n', 'Englishman']
file_stuff_new = [x for x in file_stuff if x != '\n']
file_stuff_new = [x.replace('\n', '') for x in file_stuff_new]
file_stuff_new
['John Smith', 'Gardener', 'Age 27', 'Englishman']
这显然有效。还有其他建议吗?在
您使用的是原始字符串文本。在
r'\n'
不是换行符,它是一个长度为2的字符串,包含字符“\”和“n”。在否则,您最初的方法(几乎)可以工作。在
^{pr2}$我们可以像这样过滤空字符串:
其中
no_newline
是一个内存效率高的生成器,它不构建中间临时列表。在如果只想从字符串的开头和结尾去掉空格和换行符,请考虑
str.strip
方法。在这可以缩短为
如果您能处理每个字符串两次调用
str.strip
的不雅问题。在这个例子是简单的列表理解,条件是:
可以使用strip(),如:
若要从列表中删除空项,请使用筛选器,例如
^{pr2}$相关问题 更多 >
编程相关推荐