栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Python

python文件读取 readlines()方法之坑

Python 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

python文件读取 readlines()方法之坑

一、需求:

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

     1.txt1231
     2.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

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/221929.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号