29讲文件对比代码
29讲的课后中,要求程序对比两个文件的不同点,统计出哪一行有不同。参考答案的代码如下:
我的疑问:
该程序利用以下for循环让两个文件进行一一对比,如果第二个文件比第一个文件的行数多,那么利用该方法就不能对比出第二个文件多出来的行数。
请问该如何解决?
def file_compare(file1, file2):
f1 = open(file1)
f2 = open(file2)
count = 0 # 统计行数
differ = [] # 统计不一样的数量
for line1 in f1:
line2 = f2.readline()
count += 1
if line1 != line2:
differ.append(count)
f1.close()
f2.close()
return differ
file1 = input('请输入需要比较的第一个文件名:')
file2 = input('请输入需要比较的第二个文件名:')
differ = file_compare(file1, file2)
if len(differ) == 0:
print('两个文件完全一样!')
else:
print('两个文件共有【%d】处不同:' % len(differ))
for each in differ:
print('第 %d 行不一样' % each)
有一个想法,你可以先统计每个文件的行数,然后逐行对比,如果匹配成功,就打印出相匹配的行数,最后统计有几行文字是相同的 def file_compare(file1, file2):
f1 = open(file1)
f2 = open(file2)
k1 = f1.readlines()
k2 = f2.readlines()
if len(k1) < len(k2):
k1, k2 = k2, k1
differ = [] # 统计不一样的数量
for index in range(len(k1)):
try:
if k1 != k2:
differ.append(index + 1)
except IndexError:
differ.append(index + 1) kylin121380 发表于 2020-9-28 18:55
感谢大佬
小甲鱼的“[扩展阅读] 文件的打开模式和文件对象方法” 没有讲到readlines()
受教了
页:
[1]