python文件读取 readlines()方法之坑,pythonreadlines,一、需求:有类似如下
python文件读取 readlines()方法之坑,pythonreadlines,一、需求:有类似如下
一、需求:有类似如下两个文件需要交差对比,进行处理。
1.txt1231
2.txtABCD
二、问题:
首先想到的是打开之后,两次for循环就是了
#错误写法f1=open(r"D:\pytest\1.txt",‘r‘)f2=open(r"D:\pytest\2.txt",‘r‘)for x in f1.readlines(): for y in f2.readlines(): print(x.strip()+y.strip())
输出结果只有
1A1B1C1D
明显第一层未循环完成啊。
于是测啊测,找啊找,终于明白了。readlines()是一次性工作,读入内存后迭代完成就没有了
#输出测试f1=open(r"D:\pytest\1.txt",‘r‘)f2=open(r"D:\pytest\2.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 : [‘A\n‘, ‘B\n‘, ‘C\n‘, ‘D‘] #明显只请求一次X : 1y:AX : 1y:BX : 1y:CX : 1y:Dx2 is : [] #之后不再重新请求,已成空值,外层停止循环x2 is : []x2 is : []
三、解决
可以给它在外层赋个变量存储一下。修改代码如下,终于2层循环正常输出了。
#可用写法1f1=open(r"D:\pytest\1.txt",‘r‘)f2=open(r"D:\pytest\2.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:\pytest\1.txt",‘r‘) as f1,open(r"D:\pytest\2.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()方法之坑
相关内容
- IIS 部署 python web框架 Flask,pythonflask,IIS的安装就不说了
- python基础学习11天,作业题,python11天,1. 文件a.txt
- windows下安装python的numpy,scipy,sklearn,numpyscipy,前提环
- 在mac上安装python-opencv,并在pycharm测试,,在网上找了一
- python脚本分析Nginx的每个IP的访问次数,pythonnginx,目的介
- centos7 Python安装及yum问题解决,centos7yum,centos7 Py
- python——求交通肇事者的车牌号,python交通肇事,例子:
- Python实现macof,pythonmacof,import sys
- Python replace()方法,pythonreplace方法,描述Python r
- python ConfigParser读取配置文件,及解决报错ConfigParser.M
评论关闭