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

 更新时间:2024年06月24日 09:33:03   作者:冰美式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文件的开头第一行,我们都会看到下面的代码行

  • 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

总结

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

您可能感兴趣的文章:

相关文章

  • Python实现读取SQLServer数据并插入到MongoDB数据库的方法示例

    Python实现读取SQLServer数据并插入到MongoDB数据库的方法示例

    这篇文章主要介绍了Python实现读取SQLServer数据并插入到MongoDB数据库的方法,涉及Python同时进行SQLServer与MongoDB数据库的连接、查询、读取、写入等相关操作实现技巧,需要的朋友可以参考下
    2018-06-06
  • python如何读取指定csv单元格

    python如何读取指定csv单元格

    这篇文章主要介绍了python如何读取指定csv单元格方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-02-02
  • 深入理解python虚拟机如何实现闭包

    深入理解python虚拟机如何实现闭包

    当能够从设计者的层面去理解闭包就再也不用死记硬背一些闭包的概念了,所以本文就来从虚拟机层面和大家一起讨论函数闭包是如何实现的
    2023-10-10
  • Python使用python-pptx实现设置PPT页面与文档属性

    Python使用python-pptx实现设置PPT页面与文档属性

    这篇文章主要为大家详细介绍了Python如何使用python-pptx实现设置PPT页面与文档属性,文中的示例代码讲解详细,感兴趣的小伙伴可以了解一下
    2026-04-04
  • ruff check文件目录检测--exclude参数设置路径详解

    ruff check文件目录检测--exclude参数设置路径详解

    这篇文章主要为大家介绍了ruff check文件目录检测exclude参数如何设置多少路径详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-10-10
  • Python语言描述KNN算法与Kd树

    Python语言描述KNN算法与Kd树

    这篇文章主要介绍了Python语言描述KNN算法与Kd树,具有一定借鉴价值,需要的朋友可以参考下。
    2017-12-12
  • Python实现中英文文本朗读的三种常用方法

    Python实现中英文文本朗读的三种常用方法

    本文介绍了Python实现中英文文本朗读的三种常用方法,1,pyttsx3:基于系统语音引擎,无需联网,可调节语速和音量,但语音较机械;2,gTTS:利用Google API生成高质量语音,需联网并生成临时文件;3, edge-tts:采用微软Azure,需要的朋友可以参考下
    2026-04-04
  • 基于python图书馆管理系统设计实例详解

    基于python图书馆管理系统设计实例详解

    这篇文章主要介绍了基于python图书馆管理系统设计实例详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-08-08
  • Python实现某论坛自动签到功能

    Python实现某论坛自动签到功能

    这篇文章主要介绍了Python实现论坛自动签到功能,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-08-08
  • Python之random库的常用函数有哪些

    Python之random库的常用函数有哪些

    这篇文章主要为大家详细介绍了Python之random库的常用函数,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2022-02-02

最新评论