|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
看了答案有一点不明白的地方:
for line1 in f1:
line2 = f2.readline()
这里为什么能够实现逐行对比呢?
或者说for循环是怎么循环的呢?
x萌新仰望各位大佬,求助。。。猛男嘤嘤嘤
答案是:
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)
文件对象是可以迭代的。for line1 in f1 就是将 f1 中的每一行保存到 line1 变量,line2 = f2.readline() 就是将 f2 往下读取一行的结果赋值给 line2 变量。
|
|