我对一个非常简单的代码有一个问题。我有一个6551行的文件(ASCII),到目前为止我所做的就是读取文件并打印出来。
a_file = open(myfile_path).readlines()
print a_file翻译一试打印,就会被完全卡住几分钟。我在懒散和jetbrains的侏儒中都试过这种方法。我正在运行windows服务器2012作为我的工作站和windows 7在家里-有趣的是,这是完美的工作在较弱的windows 7机器(q9550和8gb内存)-但我不能(和两个it人)找到一个解决方案在我的工作站(i7 on x99,64 8gb内存,gtx980)。
将感谢所有和任何的帮助。
发布于 2015-07-13 16:46:38
将文件读入内存(这正是您所做的)并不是一个好主意,因为您可能会遇到问题。
如果要打印文件的每一行,可以使用以下构造:
with open(myfile_path) as input_file:
for line in input_file:
print line对于更复杂的操作,您(或IT人员)应该更好地处理open()方法的文档和文件操作。
发布于 2015-07-13 16:53:34
首先,尝试如下:
import sys
with open(myfile_path) as f:
for line in f:
print f
sys.stdout.flush()它可能是导致脚本挂起的许多事情,例如打开或锁定的文件或输出阻塞。这将导致所有可以打印的东西打印出来。
此外,通常一次做一行是有益的,除非您实际上同时需要列表中的所有行--这不应该是这里的根本原因,除非行长度确实很大,但是不分配巨大的数据结构是很好的风格。
此外,在文件上设置非阻塞模式将解决诸如写入和锁定的文件之类的问题(虽然这不会给您一个稳定的解决方案,但它将在读取时停止阻塞)。这是依赖操作系统的,可能不会比伤害更多的帮助你。
如果问题是要将文件写入其中(我在Windows中经常遇到这种情况),另一种选择是将被写入的文件复制到临时文件中,并将该副本传递给脚本。
您选择做什么将在很大程度上取决于您是要确保您拥有所有可能的数据,还是希望确保脚本立即运行。
https://stackoverflow.com/questions/31388839
复制相似问题