|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
原题目:
1. 编写一个程序,比较用户输入的两个文件,如果不同,显示出所有不同处的行号与第一个不同字符的位置,程序实现如图:
标准答案(在本Python code 存储的文件夹位置,我自己新建了两个文本,a.txt 和 b.txt。 但 copy以下答案,运行后,报错)
- 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)
复制代码
报错内容:
- 请输入需要比较的头一个文件名:a.txt
- 请输入需要比较的另一个文件名:b.txt
- Traceback (most recent call last):
- File "F:/20210119b.py", line 20, in <module>
- differ = file_compare(file1, file2)
- File "F:/20210119b.py", line 7, in file_compare
- for line1 in f1:
- UnicodeDecodeError: 'gbk' codec can't decode byte 0x80 in position 2: illegal multibyte sequence
复制代码
难道又是因为 “小甲鱼的代码是教学用的,考虑的都是理想条件,在容错性和代码精简方面不是很到位”?请高手帮助。
编码问题,第二行第三行open方法加个encoding='utf-8'的参数再试试
|
|