Python 官方文档:入门教程 => 点击学习
一、需求: 有类似如下两个文件需要交差对比,进行处理。 1.txt 1 2 3 1 2.txt A B C D 二、问题: 首先想到的是打开之后,两次for循环就是了 #错误写法 f1=open(r"D:\pytest\
有类似如下两个文件需要交差对比,进行处理。
1.txt
1
2
3
1
2.txt
A
B
C
D
首先想到的是打开之后,两次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())
输出结果只有
1A
1B
1C
1D
明显第一层未循环完成啊。
于是测啊测,找啊找,终于明白了。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 : 1
y:A
X : 1
y:B
X : 1
y:C
X : 1
y:D
x2 is : [] #之后不再重新请求,已成空值,外层停止循环
x2 is : []
x2 is : []
可以给它在外层赋个变量存储一下。修改代码如下,终于2层循环正常输出了。
#可用写法1
f1=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(),于是修改代码
#可用写法2
with 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())
--结束END--
本文标题: python文件读取 readlines
本文链接: https://lsjlt.com/news/189227.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
2024-03-01
2024-03-01
2024-03-01
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0