|
|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
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
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)
这个for 循环里的line1 为什么直接是一行文字 不应该是一个字吗?
再看看22课小甲鱼的视频,你的f1是一个文件对象,里面的数据是以行为单位的,你把f1对象转换成list试下,可以看见每个元素是包含换行符的
|
|