关于python中关于with文件引用中涉及到for循环与f.read相关的问题

代码如图所示

img


其中“a”文件的内容如下

img


但文件运行后的的结果如下

img


在这种情况下为何会出现这样的结果?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'使用的时候要留意。