Python UnicodeEncodeError: 'gbk' codec can't encode character 解决方法


Posted in Python onApril 24, 2015

使用Python写文件的时候,或者将网络数据流写入到本地文件的时候,大部分情况下会遇到:UnicodeEncodeError: 'gbk' codec can't encode character '\xa0' in position ... 这个问题。 网络上有很多类似的文件讲述如何解决这个问题,但是无非就是encode,decode相关的,这是导致该问题出现的真正原因吗?不是的。 很多时候,我们使用了decode和encode,试遍了各种编码,utf8,utf-8,gbk,gb2312等等,该有的编码都试遍了,可是编译的时候仍然出现: UnicodeEncodeError: 'gbk' codec can't encode character '\xa0' in position XXX。 崩溃了。

    在windows下面编写python脚本,编码问题很严重。

    将网络数据流写入文件时时,我们会遇到几个编码:

    1: #encoding='XXX' 这里(也就是python文件第一行的内容)的编码是指该python脚本文件本身的编码,无关紧要。只要XXX和文件本身的编码相同就行了。 比如notepad++ "格式"菜单里面里可以设置各种编码,这时需要保证该菜单里设置的编码和encoding XXX相同就行了,不同的话会报错

    2:网络数据流的编码 比如获取网页,那么网络数据流的编码就是网页的编码。需要使用decode解码成unicode编码。

    3:目标文件的编码 要将网络数据流的编码写入到新文件,那么我么需要指定新文件的编码。写文件代码如:

f.write(txt) 

,那么txt是一个字符串,它是通过decode解码过的字符串。关键点就要来了:目标文件的编码是导致标题所指问题的罪魁祸首。如果我们打开一个文件:
f = open("out.html","w") 

,在windows下面,新文件的默认编码是gbk,这样的话,python解释器会用gbk编码去解析我们的网络数据流txt,然而txt此时已经是decode过的unicode编码,这样的话就会导致解析不了,出现上述问题。 解决的办法就是,改变目标文件的编码:
f = open("out.html","w",encoding='utf-8') 

。这样,问题将不复存在。
Python 相关文章推荐
Python中关于使用模块的基础知识
May 24 Python
Python函数式编程指南(一):函数式编程概述
Jun 24 Python
Python操作csv文件实例详解
Jul 31 Python
python基础教程项目三之万能的XML
Apr 02 Python
在python中利用最小二乘拟合二次抛物线函数的方法
Dec 29 Python
python批量解压zip文件的方法
Aug 20 Python
详解python中的模块及包导入
Aug 30 Python
pycharm通过ssh连接远程服务器教程
Feb 12 Python
python mysql自增字段AUTO_INCREMENT值的修改方式
May 18 Python
详解Python利用configparser对配置文件进行读写操作
Nov 03 Python
python中print格式化输出的问题
Apr 16 Python
利用For循环遍历Python字典的三种方法实例
Mar 25 Python
Python3.x中自定义比较函数
Apr 24 #Python
使用Python脚本将绝对url替换为相对url的教程
Apr 24 #Python
Python3.x版本中新的字符串格式化方法
Apr 24 #Python
用Python的Tornado框架结合memcached页面改善博客性能
Apr 24 #Python
使用Python编写一个在Linux下实现截图分享的脚本的教程
Apr 24 #Python
修改Python的pyxmpp2中的主循环使其提高性能
Apr 24 #Python
Python的Tornado框架异步编程入门实例
Apr 24 #Python
You might like
从零开始 教你如何搭建Discuz!4.1论坛
2006/07/07 PHP
PHP中SQL查询语句的id=%d解释(推荐)
2016/12/10 PHP
浅谈PHP表单提交(POST&GET&URL编/解码)
2017/04/03 PHP
写的htc的数据表格
2007/01/20 Javascript
JavaScript Date对象 日期获取函数
2010/12/19 Javascript
jQuery Jcrop插件实现图片选取功能
2011/11/23 Javascript
各浏览器中querySelector和querySelectorAll的实现差异分析
2012/05/23 Javascript
JQuery 图片的展开和伸缩实例讲解
2013/04/18 Javascript
JavaScript学习笔记之JS事件对象
2015/01/22 Javascript
JS实现的4种数字千位符格式化方法分享
2015/03/02 Javascript
在JavaScript的正则表达式中使用exec()方法
2015/06/16 Javascript
jQuery+PHP实现微信转盘抽奖功能的方法
2016/05/25 Javascript
vue中计算属性(computed)、methods和watched之间的区别
2017/07/27 Javascript
微信小程序自定义tabBar组件开发详解
2020/09/24 Javascript
微信网页登录逻辑与实现方法
2019/04/29 Javascript
微信小程序实现折线图的示例代码
2019/06/07 Javascript
JS中数据结构与算法---排序算法(Sort Algorithm)实例详解
2019/06/17 Javascript
Python获取央视节目单的实现代码
2015/07/25 Python
pip安装Python库时遇到的问题及解决方法
2017/11/23 Python
深入浅析Python传值与传址
2018/07/10 Python
Python中断多重循环的几种方式详解
2020/02/10 Python
Python自动采集微信联系人的实现示例
2020/02/28 Python
windows python3安装Jupyter Notebooks教程
2020/04/13 Python
Joseph官网:英国小众奢侈品牌
2019/05/17 全球购物
PHP中如何使用Cookie
2015/10/28 面试题
中班上学期幼儿评语
2014/04/30 职场文书
保卫钓鱼岛口号
2014/06/20 职场文书
2014年银行员工年终自我评价
2014/09/19 职场文书
庆祝教师节标语
2014/10/09 职场文书
2015年行政工作总结范文
2015/04/09 职场文书
毕业论文致谢部分怎么写
2015/05/14 职场文书
运动会口号霸气押韵
2015/12/24 职场文书
2019学校请假条格式及范文
2019/06/25 职场文书
Nginx快速入门教程
2021/03/31 Servers
Python3 使用pip安装git并获取Yahoo金融数据的操作
2021/04/08 Python
Python用tkinter实现自定义记事本的方法详解
2022/03/31 Python