本文首先简要介绍编码转换的基本原理,然后针对字符串处理、文件读写的两个实例,具体分析编码问题的处理方式。

1、编码转换的基本原理

我们知道,只有在面对中文、日文等编码字符(以下均以中文字符为例)时,才会有编码转换问题;而英文字符串是不存在编码转换问题的,因为转来转去都不会变化。

那么分别在什么情况下编码和解码?看下面两个例子就清楚了:

1)编码:Unicode(中文字符)-->String(字符串),当需要把中文字转换为字符串时,用编码encode。

u'中国'  #Unicode
Out[1]: u'\u4e2d\u56fd' type(u'中国')
<type 'unicode'> u'中国'.encode('utf-8') #编码
Out[2]: '\xe4\xb8\xad\xe5\x9b\xbd' # String type('\xe4\xb8\xad\xe5\x9b\xbd')
<type 'str'>

2)解码:String(字符串) --> Unicode(中文字符),当需要把字符串转换回中文字时,用解码decode。

'\xe4\xb8\xad\xe5\x9b\xbd'.decode('utf-8') #解码
Out[5]: u'\u4e2d\u56fd' print u'\u4e2d\u56fd' # Unicode
中国

2、将列表中的数字、字符串、Unicode都转换为string,如何处理?

假设待处理列表为:lst = [1, 'abc', u'中国'],如果使用for循环和str()函数,会导致报错,从以下报错信息中可以发现:其实str()函数在尝试对u'中国'进行ascii编码,这当然行不通;正确的方法是单独用encode()处理Unicode字符。举例如下

错误的处理方法:

for i in lst:
print str(i) #错误的处理方法
#报错:UnicodeEncodeError:'ascii' codec can't encode characters in position 0-1: ordinal not inrange(128)

正确的处理方法:

for i in lst:
if isinstance(i, unicode): #单独处理unicode字符
print i.encode('utf-8')
else: #其余的情况用str()函数处理
print str(i) #1
#abc
#中国

3、将编码为A的数据,输出到编码为B的文件,如何处理? 

举例说明:假设源数据所采用编码为utf-8,希望将源数据保存到编码为gbk的文件。

基本思路:先将utf-8格式源数据decode()回unicode字符(python底层默认编码),注意源文件编码为utf-8,所以decode()中的参数应为utf-8;然后将源文件输出到编码为gbk的文件,注意输出到文件的过程是:将文件内容encode成为我们需要的gbk字符串。

代码如下:

content = u'中国'.encode('utf-8') #演示用:生成utf-8偏码的源数据

content = content.decode('utf-8') #使用utf-8格式解码,得到unicode字符

#源数据保存到编码为gbk的文件,相当于content.encode('gbk')后保存到文件。
path = './'
with codecs.open(path, 'wb', encoding ='gbk', errors='ignore') as f:
f.write(content)

python编码问题分析的更多相关文章

  1. BASE64编码原理分析脚本实现及逆向案例

    在互联网中的每一刻,你可能都在享受着Base64带来的便捷,但对于Base64的基础原理你又了解多少?今天小编带大家了解一下Base64编码原理分析脚本实现及逆向案例的相关内容.   01编码由来 数 ...

  2. 说说Python编码规范

    前言 已有近两个月没有发表过文章了,前段时间外甥和女儿过来这边渡暑假,平常晚上和周末时间都陪着她们了,趁这个周末有空,再抽空再把这块拾起来.         这么久没写了,再次拿起键盘,想想,发表些什 ...

  3. Python 编码规范(Google)

    Python 编码规范(Google) https://blog.csdn.net/q469587851/article/details/54096093 Python 风格规范(Google) 本项 ...

  4. Python 编码为什么那么蛋疼?

    据说,每个做 Python 开发的都被字符编码的问题搞晕过,最常见的错误就是 UnicodeEncodeError.UnicodeDecodeError,你好像知道怎么解决,遗憾的是,错误又出现在其它 ...

  5. Python编码(encode)和解码(Decode)常见的两个错误

    项目地址:https://git.io/pytips 0x07 和 0x08 分别介绍了 Python 中的字符串类型(str)和字节类型(byte),以及 Python 编码中最常见也是最顽固的两个 ...

  6. (转载) 浅谈python编码处理

    最近业务中需要用 Python 写一些脚本.尽管脚本的交互只是命令行 + 日志输出,但是为了让界面友好些,我还是决定用中文输出日志信息. 很快,我就遇到了异常: UnicodeEncodeError: ...

  7. Python 编码简单说

    先说说什么是编码. 编码(encoding)就是把一个字符映射到计算机底层使用的二进制码.编码方案(encoding scheme)规定了字符串是如何编码的. python编码,其实就是对python ...

  8. Python之路3【知识点】白话Python编码和文件操作

    Python文件头部模板 先说个小知识点:如何在创建文件的时候自动添加文件的头部信息! 通过:file--settings 每次都通过file--setings打开设置页面太麻烦了!可以通过:View ...

  9. python编码规范

    python编码规范 文件及目录规范 文件保存为 utf-8 格式. 程序首行必须为编码声明:# -*- coding:utf-8 -*- 文件名全部小写. 代码风格 空格 设置用空格符替换TAB符. ...

随机推荐

  1. springboot项目线程使用2

    线程处理的一个实际例子: @Service public class SynAsynThreadTestServiceImpl implements SynAsynThreadTestService ...

  2. python-flask-script定制manage命令

    安装: pip3 install flask-script #!/usr/bin/env python # -*- coding:utf-8 -*- from flask_script import ...

  3. 自用chrome+油猴脚本,使用迅雷下载百度云大文件,一键离线下载

    油猴是有名的火狐浏览器插件(Greasemonkey),当然也有Chrome版本(tampermonkey),甚至IE.Safari.Opera都有……虽然这些插件是由不同的开发者开发出来的,界面也可 ...

  4. set unused的用法(ORACLE删除字段)

    set unused的用法(ORACLE删除字段) 一.问题 现场有一张大数据量的分区表,数据量在10G以上.因某种原因需要删除其中的某些字段.如果直接用alter table1 drop (colu ...

  5. C# 3.0 / C# 3.5 Lambda 表达式

    概述 Lambda 表达式的本质就是匿名函数.(而匿名方法的本质是委托) “Lambda 表达式”是一个匿名函数,可以包含表达式和语句,并且可用于创建委托或表达式树类型. (Lambda 表达式的运算 ...

  6. IDEA 自动生成 serialVersionUID 的设置

    打开File菜单,选择Settings选项,打开Settings设置对话框:左边树形目录,打开Editor>Inspections

  7. Git:多人推送/抓取分支事项

    1.推送分支 1.1使用命令符git push origin branch-name,推送自己已修改的分支 例如git push origin master,git push origin dev. ...

  8. [luogu P2054] [AHOI2005]洗牌

    [luogu P2054] [AHOI2005]洗牌 题目描述 为了表彰小联为Samuel星球的探险所做出的贡献,小联被邀请参加Samuel星球近距离载人探险活动. 由于Samuel星球相当遥远,科学 ...

  9. iOS性能优化总结

    iOS性能优化总结.关于 iOS 性能优化梳理: 基本工具.业务优化.内存优化.卡顿优化.布局优化.电量优化. 安装包瘦身.启动优化.网络优化等. 关于iOS 性能优化梳理: 基本工具.业务优化.内存 ...

  10. ORM框架之SQLALchemy

    一.面向对象应用场景: 1.函数有共同参数,解决参数不断重用: 2.模板(约束同一类事物的,属性和行为) 3.函数编程和面向对象区别: 面向对象:数据和逻辑组合在一起:函数编程:数据和逻辑不能组合在一 ...