我有一个文本文件,看起来像:

ABC
DEF

我怎么能把文件读入一个单行字符串没有换行符,在这种情况下创建一个字符串'ABCDEF'?


有关将文件读入行列表,但从每行中删除末尾换行字符的操作,请参见如何读取不带换行符的文件?。


当前回答

你可以把它压缩成一两行代码!!

content = open('filepath','r').read().replace('\n',' ')
print(content)

如果你的文件是:

hello how are you?
who are you?
blank blank

python输出

hello how are you? who are you? blank blank

其他回答

Oneliner:

列表:" . join ([line.rstrip(“\ n”)在开放(file.txt)]) 生成器:"".join((line.rstrip('\n') for line in open('file.txt')))

列表比生成器快,但内存更重。生成器比列表慢,而且内存更轻,比如遍历行。在"".join()的情况下,我认为两者都应该工作得很好。.join()函数应该被删除,分别获得列表或生成器。

注意:close() /关闭文件描述符可能不需要

file = open("myfile.txt", "r")
lines = file.readlines()
str = ''                                     #string declaration

for i in range(len(lines)):
    str += lines[i].rstrip('\n') + ' '

print str

你试过这个吗?

x = "yourfilename.txt"
y = open(x, 'r').read()

print(y)

如果您不熟悉方括号语法,则python3:谷歌“列表理解”。

 with open('data.txt') as f:
     lines = [ line.strip('\n') for line in list(f) ]
from pathlib import Path   
line_lst = Path("to/the/file.txt").read_text().splitlines()

是获取文件所有行的最佳方法,'\n'已经被splitlines()剥离(它可以智能识别win/mac/unix行类型)。

但如果你想剥离每一行:

line_lst = [line.strip() for line in txt = Path("to/the/file.txt").read_text().splitlines()]

Strip()只是一个有用的示例,但是您可以按照自己的意愿处理您的行。

最后,你只想要连接的文本?

txt = ''.join(Path("to/the/file.txt").read_text().splitlines())