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 detailsProcess finished with exit code 1
python3环境中,源码文件默认使用utf-8编码,可以正常解析中文,不需要开头加上面的代码,但是为了代码的可移植性,建议在编写程序的时候加上。
另外,使用编辑器编写python程序时,还需要设置py文件存储的格式为UTF-8,否则会出现乱码或者报错。
三、#!/usr/bin/env python
一般在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 指定解释器的路径
四、#!/usr/bin/env python和# coding=utf-8
为了代码能够在linux和windows环境下都可以运行,中文编码不报错,建议在编写python程序时,在文件开头加上这两句。
#!/usr/bin/env python # coding=utf-8
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
DataFrame 数据合并实现(merge,join,concat)
这篇文章主要介绍了DataFrame 数据合并实现(merge,join,concat),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2020-06-06python pandas dataframe 行列选择,切片操作方法
下面小编就为大家分享一篇python pandas dataframe 行列选择,切片操作方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧2018-04-04Python协程 yield与协程greenlet简单用法示例
这篇文章主要介绍了Python协程 yield与协程greenlet简单用法,简要讲述了协程的概念、原理,并结合实例形式分析了Python协程 yield与协程greenlet基本使用方法,需要的朋友可以参考下2019-11-11
最新评论