今天在运用Pycharm时遇到一个错误
SyntaxError: (unicode error) ‘unicodeescape‘ codec can‘t decode bytes in position 2-3: truncated \UXXXXXXXX escape(Unicode unicodeescape”错误)的编解码器不能解码的字节的位置:在2~3 uxxxxxxxx截断
刚开始以为是不识别,于是在python文件的头部加上
#-- coding:utf-8 --
但是加完这个还是报错一脸懵逼呀。
后来在其他文件上操作,原来是路径写的 有问题,错误代码如下
f=(‘C:\Users\Administrator\PycharmProjects\untitled\full.log‘)
正确结果
f=(‘C:\Users\Administrator\PycharmProjects\untitled\full.log‘)
或者
f=open(r‘C:\Users\Administrator\PycharmProjects\untitled\full.log‘)date= f.read()print(date)
原因:
window 读取文件可以用\,但是在字符串中\是被当作转义字符来使用,所以’d:\a.txt’会被转义成’d:\a.txt’这是正确路径,所以不会报错。
而‘C:\Users\FrankYuan\Pictures\Camera Roll\WIN_20161010_08_51_57_Pro.jpg ’中经过转义之后可能就找不到路径的资源了,例如\t可能就转义成tab键了。
解决办法python在描述路径时可以有多种方式,现列举常见的三种
方式一:转义的方式‘d:\a.txt‘方式二:显式声明字符串不用转义‘d:r\a.txt‘
方式三:使用Linux的路径/‘d:/a.txt‘
原文地址:https://www.cnblogs.com/herosyuan/p/9560719.html