|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
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)
本帖最后由 Twilight6 于 2020-7-14 21:06 编辑
for line1 in f1:
line2 = f2.readline()
for 循环每次读取 f1 的一行 , 而 f2.readline() 也是每次 for 循环只执行一次 , 也就是 f2 每次也是读取文件的一行
那么他们两个每次 for 循环都是一样的 , 都只读取一行 , 而且 for 循环 和 readline() 一样 , 每次读取一行 文件指针就会移动到下一行的开头
所以每次 for 循环都是全新的一行 , for 循环一次 , readline() 函数也执行一次 , 文件指针也都移动到下一行一次 , 所以就是这样以一行 一行为单位拿来对比滴
|
|