|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
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
|
|