python文件讀取 readlines()方法之坑
阿新 • • 發佈:2018-03-08
python readlines() 文件讀取 一、需求:
有類似如下兩個文件需要交差對比,進行處理。
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())
測試環境為windows下python3.6
python文件讀取 readlines()方法之坑