代码如图所示
其中“a”文件的内容如下
但文件运行后的的结果如下
在这种情况下为何会出现这样的结果?for循环后加上read的运行逻辑是什么?
代码如图所示
f.read()实际上是有一个指针,从第一个字符开始,一直读取,并且跑到最后并不会回到起点。
当你执行了for line in f:下面时候,第一行及已经读过了,指针已经到了第二行了,然后的res读取到的f.read()实际上就已经是 剩下的所有内容了,你的for循环其实只执行了一次,下面的2 3 4 5 是一次循环输出的,不是for循环一次又一次输出的哦。
正常的流程代码给出,做参考。
with open("aaa.txt", "rt") as f:
# 先把文件的内容存到程序中,内存中,后面就不考虑文件指针的问题了。
# data = f.read()
# print(data)
# data_list = f.readlines()
# for data in data_list:
# print(data)
注意两段注释的内容一段是把文本中所有的内容读取到data中,data是一个字符串,一个是按行读取,data_list是一个包含了文本中每一行内容的一个列表,并且每一行最后都有一个'\n'使用的时候要留意。