CarterZhang 发表于 2020-11-22 10:38:41

求助:比较两个文件内容不同

题目要求:比较用户输入的两个文件,如果不同,显示出所有不同的行号和第一个不同字符的位置。

def read_file(file1,file2):
    f1 = open('file1.txt','r')
    f2 = open('file2.txt','r')
    count = 0 #统计行数
    differ = [] #统计不一样数量
    for each1 in f1:
      each2 = f2.readline()
      count += 1
      if each1 != each2:
            differ.append(count)

    f1.close()
    f2.close()
    return differ

file1 = input('please input the first file: ')
file2 = input('please input the second file: ')

differ = read_file(file1,file2)

if len(differ) == 0:
    print('These two files are same!')
else:
    print('There are %d difference' %len(differ))
    for each in differ:
      print('第%d行不一样' %differ)

我的问题是:按照这样写,如果一行有两处不同,是不是也只会输出一处?

昨非 发表于 2020-11-22 10:46:56

是的,因为这段代码是统计不一样的行数,而非不同有多少处
       if each1 != each2:
            differ.append(count)

这是我们的判断条件,很显然,两行有差异,是不会去区分有几处不同的

CarterZhang 发表于 2020-11-22 11:02:37

昨非 发表于 2020-11-22 10:46
是的,因为这段代码是统计不一样的行数,而非不同有多少处




请问如果即使一行有多处不同,也能同样输出的话,该如何写呢?
自己琢磨了一下,没有思路{:5_96:}
如果大佬有时间,麻烦指导一下!{:5_111:}

CarterZhang 发表于 2020-11-22 11:03:26

如果要能够做到一行多处不同都能够输出,该怎么改进呢?

昨非 发表于 2020-11-22 11:08:06

CarterZhang 发表于 2020-11-22 11:03
如果要能够做到一行多处不同都能够输出,该怎么改进呢?

我没有那么写过,,,感觉不太好实现的样子,大概说说思路吧,希望有帮助
思路:
不能readline一行行读取了
而且不同分为很多种,可以是多字少字,也可以是修改某个字符或某串字符等
长度相同的话倒是可以一个个字符比较,不同的话可能会出现错位呀什么的情况,会造成判断错误
{:10_266:}

疾风怪盗 发表于 2020-11-22 23:36:31

本帖最后由 疾风怪盗 于 2020-11-22 23:38 编辑

先大体比较,如果有不同,再一个字符一个字符比较
要比较两行内多个不同,可以写个递归吧?先找到第一个不同,然后继续从第一个不同的索引开始比较,找到第二个不同,再继续从第二个不同的索引开始比较。。。。。。
页: [1]
查看完整版本: 求助:比较两个文件内容不同