我是靠谱客的博主 孝顺黄蜂,最近开发中收集的这篇文章主要介绍python中readlines_python文件读取 readlines()方法之坑,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

一、需求:

有类似如下两个文件需要交差对比,进行处理。1.txt12312.txtABCD

二、问题:

首先想到的是打开之后,两次for循环就是了#错误写法f1=open(r"D:pytest1.txt",'r')f2=open(r"D:pytest2.txt",'r')for x in f1.readlines(): for y in f2.readlines(): print(x.strip()+y.strip())

输出结果只有1A1B1C1D

明显第一层未循环完成啊。

于是测啊测,找啊找,终于明白了。readlines()是一次性工作,读入内存后迭代完成就没有了#输出测试f1=open(r"D:pytest1.txt",'r')f2=open(r"D:pytest2.txt",'r')x1=f1.readlines()for x in x1: x2=f2.readlines() print('x2 is : {}'.format(x2)) for y in x2: print("X : {}".format(x.strip())) print("y:{}".format(y.strip()))

输出x2 is : ['An', 'Bn', 'Cn', 'D'] #明显只请求一次X : 1y:AX : 1y:BX : 1y:CX : 1y:Dx2 is : [] #之后不再重新请求,已成空值,外层停止循环x2 is : []x2 is : []

三、解决

可以给它在外层赋个变量存储一下。修改代码如下,终于2层循环正常输出了。#可用写法1f1=open(r"D:pytest1.txt",'r')f2=open(r"D:pytest2.txt",'r')X1=f1.readlines()X2=f2.readlines()for x in X1: for y in X2: print(x.strip()+y.strip())

查找方法的过程中,发现with open 比直接用open更清晰,且不用显性的close(),于是修改代码#可用写法2with open(r"D:pytest1.txt",'r') as f1,open(r"D:pytest2.txt",'r') as f2: f11=f1.readlines() f22=f2.readlines() for x in f11: for y in f22: print(x.strip()+y.strip())

测试环境为windows下python3.6

最后

以上就是孝顺黄蜂为你收集整理的python中readlines_python文件读取 readlines()方法之坑的全部内容,希望文章能够帮你解决python中readlines_python文件读取 readlines()方法之坑所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(71)

评论列表共有 0 条评论

立即
投稿
返回
顶部