utf-8与gbk编码都报错
从别人的github拉下来一个python脚本。
直接运行,python报错如下:
File ".\drag_files_do_event.py", line 1
SyntaxError: encoding problem: utf8
打开发现该文件第一行已经使用了注释说明文件编码是utf-8,怀疑是否实际是gbk编码。所以将注释中的编码替换成gbk。并且不放心,还将编码转换成gbk保存。
之后再次运行,依旧报错。
File "drag_files_do_event.py", line 1
SyntaxError: encoding problem: gbk
怀疑是不是我的编辑器有问题,又去尝试用notepad++及VScode分别用utf-8,gbk编码保存。折腾的怀疑人生怀疑世界,百度无果。谷歌我打不开。
问题关键是换行风格的问题
吃完午饭,想着看一下每个字符是啥,于是突然想起了notepad++的查看所有字符功能,发现换行只有LF
,是unix风格的换行,而我自己写的能跑起来的脚本,无论是utf-8编码的还是gbk编码的都是CR LF
的win风格换行。
于是我将换行风格转为win风格。问题成功解决,脚本能够跑起来。
更进一步的解决类似的问题
上面已经清楚了问题的产生是不同平台下默认的不同风格的EOL产生的问题。
于是我开始思考如何更加优雅的解决这个问题。通过搜索,我找到了git的core.autocrlf这个设置。