我有一个问题要理解迭代一个文件,这里我继续我在解释器上键入的内容和结果:
>>> f = open('baby1990.html', 'rU')
>>> for line in f.readlines():
>>> print(line)
>>> ...
>>> ... all the lines from the file appear here
>>> ...
当我再次尝试在同一个打开的文件上迭代时,我什么也没有。
>>> f = open('baby1990.html', 'rU')
>>> for line in f.readlines():
>>> print(line)
>>>
>>>
根本没有输出,要解决这个问题,我必须关闭()文件,然后再打开它进行读取
发布于 2018-08-14 10:04:04
是的,这是正常的行为。你基本上是在第一次读取文件的末尾(你可以将它描述为读取磁带),因此,除非你通过以下任何一种方法重新设置它,否则无法从它读取更多内容。f.seek(0)重新定位到文件的开头,或者关闭它然后再次打开它将从文件的开头开始。
如果你愿意,可以使用with语法代替,它会自动为你关闭文件。
例如。,
with open('baby1990.html', 'rU') as f:
for line in f:
print line
发布于 2018-08-14 11:29:19
当文件对象读取文件时,它使用指针来跟踪文件所在的位置。如果你读取了文件的一部分,那么稍后再回到它,它将恢复到你停止的位置。如果读取整个文件,并返回到同一个文件对象,就像读取一个空文件,因为指针位于文件的末尾,没有什么可读取的。你可以用file.tell()
若要查看指针在文件中的位置,请执行以下操作:
>>> file = open('myfile.txt')
>>> file.tell()
0
>>> file.readline()
'one\n'
>>> file.tell()
4L
>>> file.readline()
'2\n'
>>> file.tell()
6L
>>> file.seek(4)
>>> file.readline()
'2\n'
file.readlines()
读取整个文件并将其存储为列表。这一点很有用,因为你可以替换:
for line in file.readlines():
#do stuff
file.seek(0)
for line in file.readlines():
#do more stuff
用
lines = file.readlines()
for each_line in lines:
#do stuff
for each_line in lines:
#do more stuff
你还可以迭代一个文件,一次一行,而不是将整个文件保存在内存中(这对于非常大的文件非常有用):
for line in file:
#do stuff
https://stackoverflow.com/questions/-100002126
复制相似问题