关于替换文件内容报错
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: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
把扩展名也输入进去
比如那是个文本文件,就输入:tfl.txt
而且,程序最好和文件在一个文件夹 一个账号 发表于 2020-3-24 17:31
这种问题一般都是因为文件存储时使用的编码和 Python 打开文件时默认使用的编码不相同而引起的。
Python ...
修改后,第一次运行可以成功,第二次报错,报错后修改一下encoding=utf-8,把这个放上面的open后,又能运行一次,然后又会报错,换一下位置又可以成功了,这是怎么回事
页:
[1]