当我们的python源文件中出现中文的问题是,我们便需要指定源文件中的编码,这样解释器就会使用指定编码去解释源文件,python默认编码如果我们木有制定的话默认是ASCII
通过python官方文档,如果我们对python源文件指定编码的话我们必须如下图一样声明注释在第一行或者第二行
例如
# coding=<encoding name> 例如 # -*- coding: UTF-8 -*-
或者通过流行的编辑器 使用 公认的格式
#!/usr/bin/python # -*- coding: <encoding name> -*-
或者
#!/usr/bin/python # vim: set fileencoding=<encoding name> :
很重要的一段我们看一下为什么这么设置
More precisely, the first or second line must match the regular expression "coding[:=]\s*([-\w.]+)". The first group of this expression is then interpreted as encoding name. If the encoding is unknown to Python, an error is raised during compilation. There must not be any Python statement on the line that contains the encoding declaration
好吧,我承认有的同学懒得看英文文档,大概意思是这样:更准确的来说,第一行或者第二行必须匹配正则表达式
coding[:=]\s*([-\w.]+) 第一组表达式([-\w.]+) 被解释成一个字符编码,如果解释的编码python不知道,在编译的时候一个错误便会给出,这里必须有一个python语句在前两行并且包含编码的声明
To aid with platforms such as Windows, which add Unicode BOM marks to the beginning of Unicode files, the UTF-8 signature '\xef\xbb\xbf' will be interpreted as 'utf-8' encoding as well (even if no magic encoding comment is given). If a source file uses both the UTF-8 BOM mark signature and a magic encoding comment, the only allowed encoding for the comment is 'utf-8'. Any other encoding will cause an error.
对于windows平台 如果一个Unicode BOM标记开始于Unicode 文件, UTF-8签名'\xef\xbb\xbf' 将会被解释为utf-8编码(即使我们在注释中声明了其他编码),但是如果源文件中包含UTF-8 BOM 标记 我们在注释中提供了编码 也仅仅允许是UTF-8 否则一个错误将会给出。
1. With interpreter binary and using Emacs style file encoding comment: #!/usr/bin/python # -*- coding: latin-1 -*- import os, sys ... #!/usr/bin/python # -*- coding: iso-8859-15 -*- import os, sys ... #!/usr/bin/python # -*- coding: ascii -*- import os, sys ... 2. Without interpreter line, using plain text: # This Python file uses the following encoding: utf-8 import os, sys ... 3. Text editors might have different ways of defining the file's encoding, e.g. #!/usr/local/bin/python # coding: latin-1 import os, sys ... 4. Without encoding comment, Python's parser will assume ASCII text: #!/usr/local/bin/python import os, sys ... 5. Encoding comments which don't work: Missing "coding:" prefix: #!/usr/local/bin/python # latin-1 import os, sys ... Encoding comment not on line 1 or 2: #!/usr/local/bin/python # # -*- coding: latin-1 -*- import os, sys ... Unsupported encoding: #!/usr/local/bin/python # -*- coding: utf-42 -*- import os, sys
相关推荐
Python编码规范(Google),Python编码规范(Google),Python编码规范(Google),Python编码规范(Google),Python编码规范(Google)
PEP8Python 编码规范 将Python 的英文编码变成中文的数据规范
python编码规范 想做合格的python-er吗?那就看看python编码规范吧。 业余偶用python做做好玩的东东。觉得它真是一个好东西。python, perl,可以让程序员生活得更充实。
PEP8Python编码规范.pdf
Python开发编码规范 Python开发编码规范
Python 编码规范Python 编码规范Python 编码规范Python 编码规范Python 编码规范
PEP8 Python编码规范PDF版,本人结合牛人博客亲自整理,本想免积分分享给大家,奈何最低都要1个积分
基于python的香农编码实现,进攻大家交流学习。
在windows平台开发python时,会遇到utf-8和gbk编码不同意造成乱码的问题,将此文件放在\PYTHON_HOME\Lib\site-packages目录下,可以解决问题
Python编码规范.pdf
python编码规范,根据谷歌编码规范 https://google.github.io/styleguide/pyguide.html整理而成,帮助python程序员规范代码书写
用python实现算术编码,能够实现编码与译码。编码的方法是通过对一篇已知文章求取概率空间后,对待翻译文章进行算术编码,并能够基于已知文章重新进行算术解码。
Python 编码规范(Google).doc
Python编码PEP8规范中文版,高清版,里面介绍了代码如何更加规范。
google的python编码规范
python编码规范,基础学习知识,喜欢的来哦
Python编码规范
google的python编码规范.pdf