大佬们,我哪里错了?
大佬们,我哪里错了? 这个break用的不好,这会让内层的for循环每次又重新从第一行开始比对,其实这里不需要用到双层遍历也能实现所需要的功能,因为每次readline()方法就会读取一行,所以可以for循环阅读a,然后用if判断a的每一行与b.readline()的不同,如不同再执行相应操作。 第二点,你存放不同处所在行的空列表变量名为b和文件名的变量名重复了,这个是最致命的问题。 这段代码你参考下看看吧name1 = input('请输入需要比较的头一个文件名:')
name2 = input('请输入需要比较的另一个文件名:')
f1 = open(name1)
f2 = open(name2)
count_dif = 0
count_line = 0
dif = []
for each_line in f1:
count_line += 1
if each_line != f2.readline():
count_dif += 1
dif.append(count_line)
if dif == []:
print('两个文件完全一样')
else:
print('两个文件有【%d】处不同:' %count_dif)
for each in dif:
print('第 %d 行不一样' %each)
f1.close()
f2.close()
Hoiste 发表于 2021-5-28 11:37
这段代码你参考下看看吧
可是大佬,我还是不知道我哪里错了 Hoiste 发表于 2021-5-28 11:34
第二点,你存放不同处所在行的空列表变量名为b和文件名的变量名重复了,这个是最致命的问题。
wen1=input('请输入需要比较的头一个文件名:')
wen2=input('请输入需要比较的另一个文件名:')
a=open(wen1)
b=open(wen2)
c=0
d=[]
for q in a:
for z in b:
if z!=q:
t=b.talk()
d.append(t)
c=c+1
break
if c!=0:
print('两个文件共有【%d】处不同:' % c)
for w in d:
print('第%d行不一样' % w)
else:
print('这两个文档一样')
大佬,改成这样了,但是它说
Traceback (most recent call last):
File "F:\小甲鱼文件\第二十九讲\002\1.py", line 8, in <module>
for z in b:
UnicodeDecodeError: 'gbk' codec can't decode byte 0xb7 in position 14: illegal multibyte sequence 正天圣人 发表于 2021-5-28 12:40
wen1=input('请输入需要比较的头一个文件名:')
wen2=input('请输入需要比较的另一个文件名:')
a=open ...
编码问题,在open方法末尾加个参数encoding='utf-8' 而且你这break加了会出问题的,在思路上已经有偏差了。 Hoiste 发表于 2021-5-28 14:47
而且你这break加了会出问题的,在思路上已经有偏差了。
大佬,我知道错了。
wen1=input('请输入需要比较的头一个文件名:')
wen2=input('请输入需要比较的另一个文件名:')
a=open(wen1)
b=open(wen2)
c=0
d=[]
for q in a:
z=b.readline()
if z!=q:
t=b.talk()
d.append(t)
c=c+1
if c!=0:
print('两个文件共有【%d】处不同:' % c)
for w in d:
print('第%d行不一样' % w)
else:
print('这两个文档一样')
改成这样,错误显示Traceback (most recent call last):
File "F:\小甲鱼文件\第二十九讲\002\1.py", line 10, in <module>
z=b.readline()
UnicodeDecodeError: 'gbk' codec can't decode byte 0xb7 in position 14: illegal multibyte sequence
加了encoding='utf-8'一样的
wen1=input('请输入需要比较的头一个文件名:')
wen2=input('请输入需要比较的另一个文件名:')
a=open(wen1)
b=open(wen2)
encoding='utf-8'
c=0
d=[]
for q in a:
z=b.readline()
if z!=q:
t=b.talk()
d.append(t)
c=c+1
if c!=0:
print('两个文件共有【%d】处不同:' % c)
for w in d:
print('第%d行不一样' % w)
else:
print('这两个文档一样')
会显示一样的错误
而且encoding='utf-8'是什么意思呢?感谢大佬解答 正天圣人 发表于 2021-5-28 16:53
大佬,我知道错了。
wen1=input('请输入需要比较的头一个文件名:')
wen2=input('请输入需要比较的另一 ...
你这个talk()是啥意思,我查了下没有这个语法
wen1=input('请输入需要比较的头一个文件名:')
wen2=input('请输入需要比较的另一个文件名:')
a=open(wen1,encoding='utf-8')
b=open(wen2,encoding='utf-8')
c=1
d=[]
for q in a:
z=b.readline()
if z!=q:
print('第',c,'行不一样')
d.append(z)
c += 1
else:
c += 1
if c!=0:
print('两个文件共有【%d】处不同:' % len(d))
else:
print('这两个文档一样')
正天圣人 发表于 2021-5-28 16:53
大佬,我知道错了。
wen1=input('请输入需要比较的头一个文件名:')
wen2=input('请输入需要比较的另一 ...
encoding='utf-8' 是设置编码格式,一般电脑上保存的文件默认是 utf-8格式的,你可以另外为更改文档的格式, gbk编码是另外的格式。 fish_nian 发表于 2021-5-28 18:50
你这个talk()是啥意思,我查了下没有这个语法
talk告诉你现在指针的位置 fish_nian 发表于 2021-5-28 18:53
encoding='utf-8' 是设置编码格式,一般电脑上保存的文件默认是 utf-8格式的,你可以另外为更改文档的格 ...
谢谢 正天圣人 发表于 2021-5-28 18:58
talk告诉你现在指针的位置
{:10_266:}没找到,在文件中移动文件指针不是seek()么 fish_nian 发表于 2021-5-28 19:05
没找到,在文件中移动文件指针不是seek()么
file:///C:/Users/Lenovo/Pictures/%E9%97%AE%E9%A2%98/%E5%B0%8F%E7%94%B2%E9%B1%BC.PNG fish_nian 发表于 2021-5-28 19:05
没找到,在文件中移动文件指针不是seek()么
你去看看小甲鱼的https://www.bilibili.com/video/BV1xs411Q799?p=30,8分25 fish_nian 发表于 2021-5-28 19:05
没找到,在文件中移动文件指针不是seek()么
我打错了,是tell Hoiste 发表于 2021-5-28 14:46
编码问题,在open方法末尾加个参数encoding='utf-8'
大佬,我知道哪里错了,谢谢你
页:
[1]