HUANGyawang123 发表于 2020-7-17 18:13:27

课后作业29讲,01题,请帮忙解答

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)
请帮忙解答,感谢

zltzlt 发表于 2020-7-17 18:17:59

for line1 in f1 就是逐行读取文件 f1,line2 = f2.readline() 也是逐行读取文件。之后对 count 变量加 1,并且判断 line1 是否等于 line2,如果不等于则将 count 添加到列表 differ 中。

Twilight6 发表于 2020-7-17 18:30:56

本帖最后由 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 列表就是为了记录不同行的行数记录的


页: [1]
查看完整版本: 课后作业29讲,01题,请帮忙解答