鱼C论坛

 找回密码
 立即注册
查看: 1626|回复: 8

[已解决]29课 一个任务之比较不同

[复制链接]
发表于 2020-10-25 21:21:11 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

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

红色部分为什么放在这个位置?我把它放在下面那个if循环中也能正常运行,但小甲鱼老师把这个count+=1放在循环外有点不太理解,希望有大佬帮忙。
最佳答案
2020-10-25 21:26:26
  1. def file_compare(file1, file2):
  2.     f1 = open(file1)
  3.     f2 = open(file2)
  4.     count = 0 # 统计行数
  5.     differ = [] # 统计不一样的数量

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

  11.     f1.close()
  12.     f2.close()
  13.     return differ
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-10-25 21:26:26 | 显示全部楼层    本楼为最佳答案   
  1. def file_compare(file1, file2):
  2.     f1 = open(file1)
  3.     f2 = open(file2)
  4.     count = 0 # 统计行数
  5.     differ = [] # 统计不一样的数量

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

  11.     f1.close()
  12.     f2.close()
  13.     return differ
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-10-25 21:27:58 | 显示全部楼层
放在if里是肯定不对的,作为行数的计数器,放在if里,如果if判断失败(false),那么这一次循环就不会计数(被跳过了),count的计数就错了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-10-25 21:29:12 | 显示全部楼层
满意的话记得设为最佳
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

倒是上面count=0也解释是统计行数,但不是比较两个文件的异同吗?我以为count是两个文件不同的个数。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 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
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

还是那个例子
如果你把count放到if里,那么只有23不同的时候,count只能加一一直加到2,
这样加入differ的只有第一行和第二行,打印出来第一二行不同
显然是错的
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

也就是说count是通过行数逐个加1,排查出不同的点最后整合到列表中
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-5-12 17:22

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表