问题:我应该在Python 3中使用编码声明吗?
默认情况下,Python 3对源代码文件使用UTF-8编码。我还应该在每个源文件的开头使用编码声明吗?喜欢# -*- coding: utf-8 -*-
回答 0
因为默认值为 UTF-8,所以仅在偏离默认值时或者在依赖其他工具(例如IDE或文本编辑器)来使用该信息时,才需要使用该声明。
换句话说,就Python而言,仅当您要使用不同的编码时,才需要使用该声明。
其他工具(例如您的编辑器)也可以支持类似的语法,这就是PEP 263规范在语法上具有相当大的灵活性的原因(它必须是注释,文本coding
必须在其中,后跟a :
或=
字符以及可选的空白,然后是公认的编解码器)。
请注意,它仅适用于Python如何读取源代码。它不适用于执行该代码,因此不适用于打印,打开文件或字节与Unicode之间的任何其他I / O操作转换。有关Python,Unicode和编码的更多详细信息,强烈建议您阅读Python Unicode HOWTO或Ned Batchelder撰写的非常详尽的Pragmatic Unicode演讲。
回答 1
不,如果:
- 整个项目仅使用
UTF-8
,这是默认设置。 - 并且您确定您的IDE工具不需要每个文件中的编码声明。
是的,如果
- 您的项目依赖于不同的编码
- 或依赖于许多编码。
对于多编码项目:
如果某些文件在中进行了编码
non-utf-8
,那么即使对于这些文件,UTF-8
您也应该添加编码声明,因为黄金法则是Explicit is better than implicit.
参考:
- PyCharm不需要该声明:
- vim不需要该声明,但是:
# vim: set fileencoding=<encoding name> :
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。