765838210 发表于 2020-3-24 17:29:53

关于替换文件内容报错

file_name=input()
in_find=input()
cover=input()
l=[]
dakai=open(file_name)
for i in dakai:
    if in_find in i:
      i=i.replace(in_find,cover)
      l.append(i)
dakai.close()
dakai=open(file_name,'w')
dakai.writelines(l)
dakai.close()


我输入后:
tfl
开始
结束
Traceback (most recent call last):
File "G:\练习\1\文件练习\文件练习2.py", line 6, in <module>
    for i in dakai:
UnicodeDecodeError: 'gbk' codec can't decode byte 0x80 in position 2: illegal multibyte sequence

tfl文件里面的内容是:开始开始
   



一个账号 发表于 2020-3-24 17:31:12

本帖最后由 一个账号 于 2020-3-24 17:48 编辑

这种问题一般都是因为文件存储时使用的编码和 Python 打开文件时默认使用的编码不相同而引起的。

Python 打开文件时默认使用的编码是 GBK(也就是 cp936)

一般将打开文件时使用的编码设置为 UTF-8 即可:

file_name=input()
in_find=input()
cover=input()
l=[]
dakai=open(file_name)
for i in dakai:
    if in_find in i:
      i=i.replace(in_find,cover)
      l.append(i)
dakai.close()
dakai=open(file_name,'w', encoding="utf-8")
dakai.writelines(l)
dakai.close()

如果还是会报错,按以下步骤调整文件的编码:

用记事本打开文件,并选择【文件】-->【另存为】

在另存为时将右下角的 “编码” 选项调整为 UTF-8


这样就可以正常打开了。

此贴转载于 https://fishc.com.cn/thread-158932-1-1.html



qiuyouzhi 发表于 2020-3-24 17:31:32

把扩展名也输入进去
比如那是个文本文件,就输入:tfl.txt
而且,程序最好和文件在一个文件夹

765838210 发表于 2020-3-25 00:20:08

一个账号 发表于 2020-3-24 17:31
这种问题一般都是因为文件存储时使用的编码和 Python 打开文件时默认使用的编码不相同而引起的。

Python ...

修改后,第一次运行可以成功,第二次报错,报错后修改一下encoding=utf-8,把这个放上面的open后,又能运行一次,然后又会报错,换一下位置又可以成功了,这是怎么回事
页: [1]
查看完整版本: 关于替换文件内容报错