祝建宇 发表于 2020-10-25 21:21:11

29课 一个任务之比较不同

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

红色部分为什么放在这个位置?我把它放在下面那个if循环中也能正常运行,但小甲鱼老师把这个count+=1放在循环外有点不太理解,希望有大佬帮忙。

昨非 发表于 2020-10-25 21:26:26

def file_compare(file1, file2):
    f1 = open(file1)
    f2 = open(file2)
    count = 0 # 统计行数
    differ = [] # 统计不一样的数量

    for line1 in f1: #遍历f1中每一行
      line2 = f2.readline()
      count += 1   #count放在循环里是为了统计行数(总行数的标号),用来记录当前比较到第几行了
      if line1 != line2:
            differ.append(count) #在differ末尾添加:不同行的标号

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

昨非 发表于 2020-10-25 21:27:58

放在if里是肯定不对的,作为行数的计数器,放在if里,如果if判断失败(false),那么这一次循环就不会计数(被跳过了),count的计数就错了

昨非 发表于 2020-10-25 21:29:12

满意的话记得设为最佳

祝建宇 发表于 2020-10-25 21:36:12

昨非 发表于 2020-10-25 21:27
放在if里是肯定不对的,作为行数的计数器,放在if里,如果if判断失败(false),那么这一次循环就不会计数 ...

倒是上面count=0也解释是统计行数,但不是比较两个文件的异同吗?我以为count是两个文件不同的个数。

昨非 发表于 2020-10-25 21:40:50

祝建宇 发表于 2020-10-25 21:36
倒是上面count=0也解释是统计行数,但不是比较两个文件的异同吗?我以为count是两个文件不同的个数。

不是的,count是读取的过的所有的行数
而不同的行数在differ里
就比如:
一共五行,假设2、3行不同
count依次等于012345
下方判断if line1 != line2:成立的时候,才会加入differ中
所以differ里只有23

昨非 发表于 2020-10-25 21:42:55

祝建宇 发表于 2020-10-25 21:36
倒是上面count=0也解释是统计行数,但不是比较两个文件的异同吗?我以为count是两个文件不同的个数。

还是那个例子
如果你把count放到if里,那么只有23不同的时候,count只能加一一直加到2,
这样加入differ的只有第一行和第二行,打印出来第一二行不同
显然是错的

祝建宇 发表于 2020-10-26 17:20:26

昨非 发表于 2020-10-25 21:42
还是那个例子
如果你把count放到if里,那么只有23不同的时候,count只能加一一直加到2,
这样加入diffe ...

也就是说count是通过行数逐个加1,排查出不同的点最后整合到列表中

昨非 发表于 2020-10-26 17:21:39

祝建宇 发表于 2020-10-26 17:20
也就是说count是通过行数逐个加1,排查出不同的点最后整合到列表中

页: [1]
查看完整版本: 29课 一个任务之比较不同