Python-编码这趟浑水
最近听Alex讲到python编码,还特意用博客讲解,觉得问题严重了,于是翻看各种博客,先简单的对编码错误做一个总结,其他的后续慢慢补上,还得上班、还得学习、还得写博客?感觉有点吃不消了。各位大神不喜勿喷啊。本人是Mac电脑,终端默认编码格式utf-8
Python编码错误及解决办法
字符串是Python中最常用的数据类型,而且很多时候会用一些不属于ascii字符集的字符,这是就会抛出UnicodeDecodeError:ascii codec can't decode byte 0xc4 in position 10:oridinal not range(128)异常。这种异常在python中很容易遇到,尤其是在Python2.x中
字符串在Python3.x内部的表示是unicode编码,因此,在做编码转换时,通常需要以unicode作为转码的中间编码,即先将其他编码的字符串解码(decode)成unicode,再从unicode编码(encode)成另一种编码。但是在Python2.x中默认编码格式是ascii,就是说在没有指定Python源码编码格式的情况下,源码中所有字符都被默认为ascii码。也是因为这个根本原因,在Python2.x中经常遇到UnicodeDecodeError或者UnicodeEncodeError的异常。
Unicode为了能够处理Unicode数据,同时兼容Python某些内部模块,Python2.x中提供了Unicode这种数据类型,通过decode和encode方法可以将其他编码和unicode编码相互转换。
Python常见编码异常(几乎都出现在Python2.x中)
Python中常见的编码异常包括:SyntaxError: Non-ASCII character 、UnicodeDecodeError和UnicodeEncodeError等。
1.SyntaxError: Non-ASCII character
这种异常不是很常见,但最好解决了。只要是因为Python源码文件中存在不属于ascii字符,而且同时没有声明源码的编码格式,例如
#在Python2.x中,在文件头部没有指定编码格式 s = '土耳其大骗子'
print s #SyntaxError: Non-ASCII character '\xe5' in file /xxx/xxx/exercise-unicode.py on line 2, but no encoding declared; see http://python.org/dev/peps/pep-0263/ for details
解决办法:在文件头部声明编码格式 #!-*- encoding:utf-8 -*-或#!encoding:utf-8
Python2.x中如果不在源码文件首行指定编码格式,则无法在Python源码文件中出现非ascii字符。这是由于Python解释器默认将源码认为是ascii编码格式
2.UnicodeDecodeError
这个异常则会出现在调用decode方法时,原因是Python将其他编码格式的字符转化为unicode编码,但是字符本身的编码格式和decode传入的编码格式不一致,例如:
#Python2.x中
#!encoding:utf-8
s = '土耳其大骗子'
us = s.decode('gbk') #异常
#UnicodeDecodeError: 'gbk' codec can't decode bytes in position 4-5: illegal multibyte sequence
上面这段代码字符串字符串s默认的编码格式是“utf-8”(#!encoding:utf-8声明的意思就是:当前.py文件中所有的字符都是utf-8编码的),但是在使用decode转化为unicode编码是传入的编码格式为“gbk”,因此在转化的时候抛出UnicodeDecodeError异常。还有一种情况是在encode的时候:
#Python2.x中
#! -*- encoding:utf-8 -*- s = '土耳其大骗子'
us = s.encode('gbk') #输出
#UnicodeDecodeError: 'ascii' codec can't decode byte 0xe5 in position 0: ordinal not in range(128)
这里是s是“utf-8”编码,直接使用s.encode('gbk'),实际上是使用了系统默认的defaultencoding来解码,等价于
s.decode(defaultencoding).encode('gbk')
而s的实际编码和defaultencoding(python2.x默认是ascii)不同。
3.UnicodeEncodeError
错误的decode和encode方法会出现异常,比如使用decode方法将unicode字符串转化的时候
#! -*- encoding:utf-8 -*- s = u'土耳其大骗子'
us = s.decode('utf-8') #输出
#UnicodeEncodeError: 'ascii' codec can't encode characters in position 0-5: ordinal not in range(128)
由于在Python2.x中,字符串转化为unicode编码的时候,可以通过unicode('xxx')、u'xxx'、'xxx'.decode('utf-8'),但是本示例是将unicode编码的字符串解码,于是抛出“UnicodeEncodeError”异常
Python中编码规范
1.遵循PEP0263原则,声明编码格式(推荐)
在PEP 0263 Defining Python Source Code Encodings中提出了对Python编码问题的最基本的解决方法:在Python源码文件中声明编码格式,最常见的声明格式如下:
#!/usr/bin/python
#! -*- encoding:utf-8 -*-
表示当前.py文件的字符串编码格式都是按照“utf-8”编码的,不是读取的文件是用“utf-8”编码读取的
2.使用 u'中文' 代替中文(Python 2.x)
s1 = '中文'
s2 = u'中文'
Python中有以上两种声明字符串变量的方式,它们的主要的是编码格式的不同,其他s1的编码格式和Python头文件声明的编码格式一致,而s2的编码格式则是unicode。如果你声明的字符串变量中包含非ascii字符,最好使用s2的的声明格式,这样你可以不需要执行decode,直接对字符串进行操作,可以避免出现一个异常。
注意:Python3中不存在 u'xx'的声明方式。
3.Reset默认编码
Python中出现这么多的编码问题的根本原因是Python 2x中的默认编码是ascii,所以你可以通过以下的方式修改默认的编码格式:
import sys
sys.setdefaultencoding('utf-8')
这种方法可以解决部分编码问题,但是同时也会引入很多其他问题,得不偿失,建议不要使用这种方式。
Python-编码这趟浑水的更多相关文章
- (转载) 浅谈python编码处理
最近业务中需要用 Python 写一些脚本.尽管脚本的交互只是命令行 + 日志输出,但是为了让界面友好些,我还是决定用中文输出日志信息. 很快,我就遇到了异常: UnicodeEncodeError: ...
- Python 编码简单说
先说说什么是编码. 编码(encoding)就是把一个字符映射到计算机底层使用的二进制码.编码方案(encoding scheme)规定了字符串是如何编码的. python编码,其实就是对python ...
- Python之路3【知识点】白话Python编码和文件操作
Python文件头部模板 先说个小知识点:如何在创建文件的时候自动添加文件的头部信息! 通过:file--settings 每次都通过file--setings打开设置页面太麻烦了!可以通过:View ...
- python编码规范
python编码规范 文件及目录规范 文件保存为 utf-8 格式. 程序首行必须为编码声明:# -*- coding:utf-8 -*- 文件名全部小写. 代码风格 空格 设置用空格符替换TAB符. ...
- 【转】python编码的问题
摘要: 为了在源代码中支持非ASCII字符,必须在源文件的第一行或者第二行显示地指定编码格式: # coding=utf-8 或者是: #!/usr/bin/python # -*- coding: ...
- 【转】python编码规范
http://blog.csdn.net/willhuo/article/details/49300441 决定开始Python之路了,利用业余时间,争取更深入学习Python.编程语言不是艺术,而是 ...
- python 编码 UnicodeDecodeError
将一个py脚本从Centos转到win运行,出错如下: UnicodeDecodeError: 'gbk' codec can't decode byte 0xff in position 0: il ...
- Python编码/文件读取/多线程
Python编码/文件读取/多线程 个人笔记~~记录才有成长 编码/文件读取/多线程 编码 常用的一般是gbk.utf-8,而在python中字符串一般是用Unicode来操作,这样才能按照单个字 ...
- 关于Python编码,超诡异的,我也是醉了
Python的编码问题,真是让人醉了.最近碰到的问题还真不少.比如中文文件名.csv .python对外呈现不一致啊,感觉好不公平. 没图说个JB,下面立马上图. 我早些时候的其他脚本,csv都是 ...
- 规范的python编码
规范的 python 编码令人赏心悦目,令代码的表达逻辑更清晰,使得工程代码更容易被维护和交流: 编码规范包括对于代码书写格式的约束,不良语法的禁用和推荐的编码手法,下面做些简要的描述: 1. 代码规 ...
随机推荐
- sass @import 规则
@import 根据文件名引入. 默认情况下,它会寻找 Sass 文件并直接引入, 但是,在少数几种情况下,它会被编译成 CSS 的 @import 规则: 如果文件的扩展名是 .css. 如果文件名 ...
- Python---基础---dict和set2
2019-05-21 写一个程序来管理用户登陆系统的用户信息:登陆名字和密码,登陆用户账号建立后,已存在用户可以用登陆名字和密码重返系统,新用户不能用别人的用户名建立用户账号 ------------ ...
- Oracle12c修改时区
Oacle12c支持可插入数据库(PDB)在一个统一的数据库(CDB)中具有不同的字符集.时区文件版本和数据库时区. 出于性能原因,Oracle建议将数据库时区设置为UTC(0:00),因为不需要转换 ...
- Dubbo学习-1-基础知识
分布式基础理论 1.什么是分布式系统: 分布式系统是若干独立计算机的集合,这些计算机对于用户来说就像是单个相关系统.分布式系统是建立在网络之上的软件系统 随着互联网发展,网站应用规模的不断扩大,常规的 ...
- CF1073G Yet Another LCP Problem 后缀自动机 + 虚树 + 树形DP
题目描述 记 $lcp(i,j)$ 表示 $i$ 表示 $i$ 这个后缀和 $j$ 这个后缀的最长公共后缀长度给定一个字符串,每次询问的时候给出两个正整数集合 $A$ 和 $B$,求$\sum_{i\ ...
- spfa求次短路
思路:先算出每个点到1的最短路d1[i],记录下路径,然后枚举最短路上的边 删掉之后再求一遍最短路,那么这时的最短路就可能是答案. 但是这个做法是错误的,可以被卡掉. 比如根据下面的例题生成的一个数据 ...
- nginx: [emerg] open() "/var/run/nginx/nginx.pid" failed (2: No such file or directory)
测试服务器 问题描述 [root@g-s-- nginx]# /usr/sbin/nginx -c /etc/nginx/nginx.conf open() : No such file or dir ...
- UPDATE 在不同数据库中的使用方式
MYSQL 中update 表一 set Gmoney = 表二.列名 from 表一,表二 where 表一.EMPID = 表二.EMPID举例:update table1 set table1. ...
- 201903-2 CCF 二十四点
题面: 考场写的30分== #include<bits/stdc++.h> using namespace std; stack<int>st; stack<char&g ...
- [CSP-S模拟测试]:凤凰院凶真(LCIS)
题目描述 $\alpha$世界线.凤凰院凶真创立了反抗$SERN$统治的组织“瓦尔基里”.为了脱离$\alpha$线,他需要制作一个世界线变动率测量仪.测量一个世界线相对于另一个世界线的变动率,实质上 ...