python文件头部声明#coding=utf-8问题

sunny123456 / 2024-09-20 / 原文

python文件头部声明#coding=utf-8问题

Python客栈送红包、纸质书

一、python2和python3默认编码

python2默认的编码格式是ASCII格式,python3默认的编码格式是utf-8格式。

pycharm控制台输入如下命令,可以获取当前python环境下的默认编码格式

?
1
2
3
4
//python2环境
>>import sys
>>sys.getdefaultencoding()
>>'ascii'
登录后复制讲解
?
1
2
3
4
//python3环境
>>import sys
>>sys.getdefaultencoding()
>>'utf-8'
登录后复制讲解

二、# coding=utf-8

在python2环境中编写python代码时,如果代码(或者注释)有中文,需要在python文件的开头加入

?
1
2
3
# -*- coding: UTF-8 -*-
或者
# coding=utf-8
登录后复制讲解

注意:# coding=utf-8 的 = 号两边不要空格。

如果未指定编码格式,使用默认编码格式ASCII码,那么在执行该文件时,会出现报错:

?
1
2
s = "中文"
print(s)
登录后复制讲解

E:\PycharmProjects\LEDdisplay2\venv\Scripts\python.exe E:/PycharmProjects/LEDdisplay2/2.py
  File "E:/PycharmProjects/LEDdisplay2/2.py", line 1
SyntaxError: Non-ASCII character '\xe4' in file E:/PycharmProjects/LEDdisplay2/2.py on line 1, but no encoding declared; see http://python.org/dev/peps/pep-0263/ for details

Process finished with exit code 1

python3环境中,源码文件默认使用utf-8编码,可以正常解析中文,不需要开头加上面的代码,但是为了代码的可移植性,建议在编写程序的时候加上

另外,使用编辑器编写python程序时,还需要设置py文件存储的格式为UTF-8,否则会出现乱码或者报错。

三、#!/usr/bin/env python

一般在python文件的开头第一行,我们都会看到下面的代码行

  • python2
?
1
2
3
#!/usr/bin/env python
或者
#!/usr/bin/python
登录后复制讲解
  • python3
?
1
2
3
#!/usr/bin/env python3
或者
#!/usr/bin/python3
登录后复制讲解

这行代码只对 Linux/Unix 用户适用,用来指定本脚本用什么解释器来执行。

其他环境下等同于注释。

为了代码的可移植性,建议在编写程序的时候加上。

1.这行代码是什么意思?

要理解这行代码,需要把这一行语句拆分成两个部分

  • 第一部分是 #!
  • 第二部分是 /usr/bin/env python

关于 #! 这个符号,叫做shebang或者sha-bang,有的翻译组将它译为 释伴,即“解释伴随行”的简称,同时又是shebang的音译。

Shebang通常出现在类Unix系统的脚本中第一行,作为前两个字符。在Shebang之后,可以有一个

或数个空白字符,后接解释器的绝对路径,用于指明执行这个脚本文件的解释器。

2.#!/usr/bin/python和#!/usr/bin/env python的区别

  • #!/usr/bin/python 是告诉操作系统执行这个脚本的时候,调用 /usr/bin 下的 python 解释器。
  • #!/usr/bin/env python 这种用法是为了防止操作系统用户没有将 python 装在默认的 /usr/bin 路径里。当系统看到这一行的时候,首先会到 env 设置里查找 python 的安装路径,再调用对应路径下的解释器程序完成操作。
  • #!/usr/bin/python 相当于写死了 python 路径。
  • #!/usr/bin/env python 会去环境设置寻找 python 目录,可以增强代码的可移植性,推荐这种写法

有这句的,加上执行权限后,可以直接用 ./ 执行,不然会出错,因为找不到 python 解释器。

  • 调用方法1:
?
1
python script.py
登录后复制讲解

#!/usr/bin/python 被忽略,等同于注释

  • 调用方法2:
?
1
./script.py
登录后复制讲解

#!/usr/bin/python 指定解释器的路径

四、#!/usr/bin/env python和# coding=utf-8

为了代码能够在linux和windows环境下都可以运行,中文编码不报错,建议在编写python程序时,在文件开头加上这两句。

?
1
2
#!/usr/bin/env python
# coding=utf-8
登录后复制讲解

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

原文链接:https://www.jb51.net/python/323154mhj.htm