python

关注公众号 jb51net

关闭
首页 > 脚本专栏 > python > python文件头部声明#coding=utf-8

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

作者:冰美式QAQ

这篇文章主要介绍了python文件头部声明#coding=utf-8问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

一、python2和python3默认编码

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

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

//python2环境
>>import sys
>>sys.getdefaultencoding()
>>'ascii'
//python3环境
>>import sys
>>sys.getdefaultencoding()
>>'utf-8'

二、# coding=utf-8

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

# -*- coding: UTF-8 -*-
或者
# coding=utf-8

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

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

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文件的开头第一行,我们都会看到下面的代码行

#!/usr/bin/env python
或者
#!/usr/bin/python
#!/usr/bin/env python3
或者
#!/usr/bin/python3

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

其他环境下等同于注释。

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

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

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

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

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

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

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

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

python script.py 

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

./script.py 

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

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

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

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

总结

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

您可能感兴趣的文章:
阅读全文