马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
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)
问题:1.count 在计算行数,但是后面并没有用到这个count啊 有什么用啊?
2.最后的 for each in differ:
print('第 %d 行不一样' % each)
这里的 each不是重新作为元素放进 列表differ里面了吗?为什么还能返回 数字呢?而且就算返回数字,他的位置也不是原来列表里的位置了啊?
求解答 ㅠㅠ 感激不尽!!!
1,你可以去掉值之后看看结果。
2,这是遍历整个differ,里面的东西就是那些
不同地方的行数。
|