解释:此时我们会发现,2是无法打印出来的,原来py中也存在类似c/c++中考虑指针位置的问题

  其实这个很好理解,当我门打开文件并遍历一遍后,文件指针自然会来到文件得最为尾端,在c/c++中我们只需将指针位置重新挪到开头即可,可是我们是python呀,怎么可以那么蠢!

  解决方法:

  (一)
将readlines()返回得对象存储起来

    例如1:
list1 = open(r"./1.txt").readlines()
for i in list1:
    print 1
for i in list1:
    print 2
file_obj = open(r"./1.txt")
list1 = file_obj.readlines()
for i in list1:
    print 1
for i in list1:
    print 2
file_obj.close()

(二)将文件打开两次

with open('./1.txt', 'r') as f:
    for i in f.readlines():
        print 1
with open('./1.txt', 'r') as f:
    for i in f.readlines():
        print 2
for i in open(r"./1.txt").readlines():
    print 1
for i in open(r"./1.txt").readlines():
    print 2

总结:前两个例子只需要对文件打开一次,后两个例子等于对文件进行了两次打开,但是四种方法都可以做到我们想要的结果。

推荐:当处理的log数据量不大的时候,个人推荐使用 例2 ,因为只需要打开一次,之后都是对对象进行操作了。

当处理的文件很大的时候建议使用 例3 ,因为with有神奇的用处,不但可以自动调用close()方法,还可以有保险的作用,当文件特别大,内存不够的时候,它可以自动限制每次的大小,使得程序顺利的走下去

问题: 例1和例4 中在这里想向大神们提出个问题,从代码量上这两种无疑少了很多,但是问题是虽然可以正常的得到我们想要的,可是文件打开之后 终究是没有关闭 的, 因为没有file对象,导致无法调用close(),这样会造成怎样的影响?最终又是谁去处理这个问题? 我的理解可能就是py的强大最终程序结束的时候自我处理了, 那这样写会不会很消耗资源,更严重的是会不会导致py的内存泄露呢? 目前我的认知py怎么可能内存泄漏,毕竟它那么强大。哈哈哈!!!

用心写每一篇博客