鱼C论坛

 找回密码
 立即注册
查看: 4252|回复: 2

[已解决]Python关于文件的读取

[复制链接]
发表于 2017-4-20 09:08:37 | 显示全部楼层 |阅读模式

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

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

x
小甲鱼课后第29讲问题:

  1. def judge():
  2.     file_name_1 = input('请输入需要比较的头一个文件名(带扩展名):')
  3.     file_name_2 = input('请输入需要比较的另一个文件名(带扩展名):')
  4.     file_1 = open(file_name_1)
  5.     file_2 = open(file_name_2)
  6.     count = 0
  7.     list1 = []
  8.     p1 = file_1.seek(0, 2)
  9.     p2 = file_2.seek(0, 2)
  10.     file_1.seek(0, 0)
  11.     file_2.seek(0, 0)[code]
  12.     while True:
复制代码

        if file_1.readline() != file_2.readline():
            count += 1
            list1.append(count)
        if file_1.tell() == p1 and file_2.tell() == p2:
            break

    file_1.close()
    file_2.close()

    print('两个文件共有【%d】处不用:' % count)
    for each in list1:
        print('第%d行不一样' % each)
        
judge()
[/code]

我已开始这样写为什么结果一直错误?
后面我改成这样就对了:

  1. def judge():
  2.     file_name_1 = input('请输入需要比较的头一个文件名(带扩展名):')
  3.     file_name_2 = input('请输入需要比较的另一个文件名(带扩展名):')
  4.     file_1 = open(file_name_1)
  5.     file_2 = open(file_name_2)
  6.     count = 0
  7.     list1 = []
  8.     list2 = []
  9.     list3 = []

  10.     for each_line in file_1:
  11.         list1.append(each_line)
  12.     for each_line in file_2:
  13.         list2.append(each_line)

  14.     len1 = len(list1)
  15.     len2 = len(list2)
  16.     x= (len1 if len1 > len2 else len2)
  17.     for i in range(x):
  18.         if list1[i] != list2[i]:
  19.             count += 1
  20.             list3.append(i+1)

  21.     file_1.close()
  22.     file_2.close()

  23.     print('两个文件共有【%d】处不用:' % count)
  24.     for each in list3:
  25.         print('第%d行不一样' % each)

  26. judge()
复制代码


我感觉这两段代码实现的方法基本一样啊?
最佳答案
2017-4-20 09:32:10
本帖最后由 lumber2388779 于 2017-4-20 09:35 编辑

因为你第一份代码count变化只有在file_1.readline() != file_2.readline()
那你的count统计的只是不同的行数,并没有随行数增加,所以你list1存储的其实只是count的累加过程,就是1-n而已
第二份代码i会随读取的行数变化而变化,所以就是对的
修改代码如下

  1. def judge():
  2.     file_name_1 = input('请输入需要比较的头一个文件名(带扩展名):')
  3.     file_name_2 = input('请输入需要比较的另一个文件名(带扩展名):')
  4.     file_1 = open(file_name_1)
  5.     file_2 = open(file_name_2)
  6.     count = 0
  7.     lines = 0
  8.     list1 = []
  9.     p1 = file_1.seek(0, 2)
  10.     p2 = file_2.seek(0, 2)
  11.     file_1.seek(0, 0)
  12.     file_2.seek(0, 0)
  13.     while True:
  14.         lines += 1
  15.         if file_1.readline() != file_2.readline():
  16.             count += 1
  17.             list1.append(lines)
  18.         if file_1.tell() == p1 and file_2.tell() == p2:
  19.             break

  20.     file_1.close()
  21.     file_2.close()

  22.     print('两个文件共有【%d】处不用:' % count)
  23.     for each in list1:
  24.         print('第%d行不一样' % each)
  25.         
  26. judge()
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2017-4-20 09:32:10 | 显示全部楼层    本楼为最佳答案   
本帖最后由 lumber2388779 于 2017-4-20 09:35 编辑

因为你第一份代码count变化只有在file_1.readline() != file_2.readline()
那你的count统计的只是不同的行数,并没有随行数增加,所以你list1存储的其实只是count的累加过程,就是1-n而已
第二份代码i会随读取的行数变化而变化,所以就是对的
修改代码如下

  1. def judge():
  2.     file_name_1 = input('请输入需要比较的头一个文件名(带扩展名):')
  3.     file_name_2 = input('请输入需要比较的另一个文件名(带扩展名):')
  4.     file_1 = open(file_name_1)
  5.     file_2 = open(file_name_2)
  6.     count = 0
  7.     lines = 0
  8.     list1 = []
  9.     p1 = file_1.seek(0, 2)
  10.     p2 = file_2.seek(0, 2)
  11.     file_1.seek(0, 0)
  12.     file_2.seek(0, 0)
  13.     while True:
  14.         lines += 1
  15.         if file_1.readline() != file_2.readline():
  16.             count += 1
  17.             list1.append(lines)
  18.         if file_1.tell() == p1 and file_2.tell() == p2:
  19.             break

  20.     file_1.close()
  21.     file_2.close()

  22.     print('两个文件共有【%d】处不用:' % count)
  23.     for each in list1:
  24.         print('第%d行不一样' % each)
  25.         
  26. judge()
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2017-4-20 10:42:07 | 显示全部楼层
lumber2388779 发表于 2017-4-20 09:32
因为你第一份代码count变化只有在file_1.readline() != file_2.readline()
那你的count统计的只是不同的行 ...

懂了 谢谢!果然没考虑周全
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-5-18 22:09

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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