python2默认的编码格式是ASCII格式,python3默认的编码格式是utf-8格式。
pycharm控制台输入如下命令,可以获取当前python环境下的默认编码格式
//python2环境
>>import sys
>>sys.getdefaultencoding()
>>'ascii'
//python3环境
>>import sys
>>sys.getdefaultencoding()
>>'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,否则会出现乱码或者报错。
一般在python文件的开头第一行,我们都会看到下面的代码行
python2
#!/usr/bin/env python
或者
#!/usr/bin/python
python3
#!/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:
python script.py
#!/usr/bin/python 被忽略,等同于注释
调用方法2:
./script.py
#!/usr/bin/python 指定解释器的路径
为了代码能够在linux和windows环境下都可以运行,中文编码不报错,建议在编写python程序时,在文件开头加上这两句。
#!/usr/bin/env python
# coding=utf-8