问题描述
我有2个这样的文件。
文件1
e 1 0 ppp
e 3 1 rrr
e 3 2 rrr
文件2
e 1 0 rrr
我想分割每一行代码以比较array [3],如果同一行中的rrr应该打印OK
。
我写这样的代码。
file1 = open('file1.txt', 'r', encoding="utf8")
file2 = open('file2.txt', 'r')
for line1 in file1: #loop file1
L1 = line1.split() #split to array
if(L1[0] == 'e'):
print("line1 " + line1)
for line2 in file2: #loop file2
L2 = line2.split() #split to array
if(L2[0] == 'e'):
print("line2 " + line2)
if(L2[3] == L1[3]): #check rrr same
print("OK")
当我运行代码时,它显示以下内容:
line1 e 1 0 ppp
line2 e 1 0 rrr
line1 e 3 1 rrr
line1 e 3 2 rrr
代码是循环循环,我想显示如下结果:
line1 e 1 0 ppp
line2 e 1 0 rrr
line1 e 3 1 rrr
line2 e 1 0 rrr
line1 e 3 2 rrr
line2 e 1 0 rrr
如何修改代码以比较文件的每一行?
1楼
基本上,您需要跟踪两个文件的最后一行。 如果文件中的任何一个较小,并且在另一个文件之前完成迭代。 您需要将当前行与其他文件的前一行进行比较。
这个怎么样?
prev_f1_token = None
prev_f1_line = None
prev_f2_token = None
prev_f2_line = None
with open('file1.txt') as f1:
with open('file2.txt') as f2:
for line in f1:
prev_f1_token = line[0]
prev_f1_line = line
for line in f2:
prev_f2_token = line[0]
prev_f2_line = line
if(prev_f1_token == 'e'):
print("line1 ", prev_f1_line)
if (prev_f2_token == 'e'):
print ("line2 ", prev_f2_line)
if(prev_f2_line.split()[3] == prev_f1_line.split()[3]): #check rrr same
print("OK")
2楼
您编写的代码远远超出了所需的数量,如果代码缩进得太多,那么继续编写代码并不总是一个好主意。 这是我尝试打印所需内容的尝试,并且我确信可以将其缩短更多!
您可以在此处使用itertools.cycle
(如果列表较短,则返回循环迭代器)
import itertools
f1, f2 = open('file1.txt', 'r'), open('file2.txt', 'r')
file1, file2 = f1.read().split(), f2.read().split()
if len(file1) > len(file2):
file2 = itertools.cycle(file2)
else:
file1 = itertools.cycle(file1)
print '\n'.join(['line1 '+i+'\nline2 '+j for i,j in zip(file1, file2)])
f1.close();f2.close()