Python 中 ‘unicodeescape’ codec can’t decode bytes in position XXX: trun错误原因分析及解决方案

表面原因:

出现这种错误的原因绝大部分是因为有句python语句涉及到了文件路径,比如:

with open('C:\Users\lenovo\Desktop\xiaotao.csv','w',encoding='utf-8') as f:

深层原因:转义

做个实验:


居然会报错???看错误提示 “position 2-3”,即“\U”,很容易联想到无符号数的转义,而“\U”后面又不是数字,故报错,修改后:

呃,“\x”是十六进制的转义,再修改:


终于ok了

我们可能不禁又要问,如果我们确实是要使用'C:\Users\lenovo\Desktop\xiaotao.csv'这样的字符串做文件路径呢?

解决办法:

很简单,在字符串前加 r ,默认不转义,即r'C:\Users\lenovo\Desktop\xiaotao.csv'

猜你喜欢

转载自blog.csdn.net/ygdxt/article/details/79427299
今日推荐