|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
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:
line2 = f2.readline()
count += 1
if line1 != line2:
differ.append(count)
请帮忙解答,感谢
本帖最后由 Twilight6 于 2020-7-17 18:31 编辑
for line1 in f1:
line2 = f2.readline()
这里两行代码,因为 for 循环是以行为单位读取文件对象内容的,而 readline() 也是以行为单位读取文件内容的
for 循环每读取一次文件,就会执行一次 f2.readline() ,他们都是把当前文件指针所在的一行读取出来,然后文件指针移动到下一行的开始,这样就达到了逐行比较的效果
count += 1
if line1 != line2:
differ.append(count)
这里 count 是为了统计行数,每次 for 循环读取一行,所读取行数就 +1
当两行字符不相同就将这一行加入 differ 列表中,这里的 differ 列表就是为了记录不同行的行数记录的
|
|