我有一个。txt文件的值。
这些值如下所示:
Value1
Value2
Value3
Value4
我的目标是将值放在一个列表中。当我这样做时,列表看起来像这样:
['Value1\n', 'Value2\n', .〕
\n不需要。
这是我的代码:
t = open('filename.txt')
contents = t.readlines()
我有一个。txt文件的值。
这些值如下所示:
Value1
Value2
Value3
Value4
我的目标是将值放在一个列表中。当我这样做时,列表看起来像这样:
['Value1\n', 'Value2\n', .〕
\n不需要。
这是我的代码:
t = open('filename.txt')
contents = t.readlines()
当前回答
打开文件后,列表理解可以在一行中完成:
fh=open('filename')
newlist = [line.rstrip() for line in fh.readlines()]
fh.close()
记得之后关闭你的文件。
其他回答
我最近用它来读取文件中的所有行:
alist = open('maze.txt').read().split()
或者你可以用这个来增加一点额外的安全:
with f as open('maze.txt'):
alist = f.read().split()
它不能在单行文本之间使用空格,但看起来您的示例文件可能没有空格分隔值。这是一个简单的解决方案,它返回一个精确的值列表,并且不为每一个空行(例如文件末尾的换行符)添加一个空字符串:”。
我会这样做:
alist = [line.rstrip() for line in open('filename.txt')]
or:
with open('filename.txt') as f:
alist = [line.rstrip() for line in f]
打开文件后,列表理解可以在一行中完成:
fh=open('filename')
newlist = [line.rstrip() for line in fh.readlines()]
fh.close()
记得之后关闭你的文件。
我使用strip函数来消除换行符,因为分割行会在4 gb的文件上抛出内存错误。
示例代码:
with open('C:\\aapl.csv','r') as apple:
for apps in apple.readlines():
print(apps.strip())
对于列表中的每个字符串,使用.strip()来移除字符串开头或结尾的空白:
for i in contents:
alist.append(i.strip())
但是根据您的用例,使用numpy之类的东西可能会更好。Loadtxt或者numpy。如果需要从文件中读取的数据数组,则使用Genfromtxt。