python2 读取excle中的数据时,对于汉字的读取报错:

代码:data[num][4]={"content": "测试"}

data=data[num][4]

UnicodeEncodeError: 'ascii' codec can't encode characters in position 13-14: ordinal not in range(128)
 
 
原因:中文编码出了问题
     python里面默认字符串都是ASCII编码,是string类型,在字符串前面加‘u'前缀可以直接声明Unicode字符串,
     但是如果处理的字符串里面出现非ascii码表示的字符(汉字),就只能转换成Unicode 
1.decode(),将其他边编码的字符串转换成unicode编码,如str1.decode('gb2312'),表示将gb2312编码的字符串str1转换成unicode编码;
2.encode(),将unicode编码转换成其他编码的字符串,如str2.encode('gb2312'),表示将unicode编码的字符串str2转换成gb2312编码;
3.unicode(),同decode(),将其他编码的字符串转换成unicode编码,如unicode(str3, 'gb2312'),表示将gb2312编码的字符串str3转换成unicode编码。
转码的时候一定要先搞明白字符串str是什么编码,然后decode成unicode,最后再encode成其他编码。
另外,对一个unicode编码的字符串在进行解码会出错,所以在编码未知的情况下要先判断其编码方式是否为unicode,可以用isinstance(str, unicode)。
不仅是中文,以后处理含非ascii编码的字符串时,都可以遵循以下步骤:
1、确定源字符的编码格式,假设是utf8;
2、使用unicode()或decode()转换成unicode编码,如str1.decode('utf8'),或者unicode(str1, 'utf8');
3、把处理后字符串用encode()编码成指定格式。 普通字符串可以用多种方式编码成Unicode字符串,具体要看你究竟选择了哪种编码:
unicodestring = u"Hello world"
# 将Unicode转化为普通Python字符串:"encode"
utf8string = unicodestring.encode("utf-8")
asciistring = unicodestring.encode("ascii")
isostring = unicodestring.encode("ISO-8859-1")
utf16string = unicodestring.encode("utf-16")
# 将普通Python字符串转化为Unicode:"decode"
plainstring1 = unicode(utf8string, "utf-8")
plainstring2 = unicode(asciistring, "ascii")
plainstring3 = unicode(isostring, "ISO-8859-1")
plainstring4 = unicode(utf16string, "utf-16")
assert plainstring1 == plainstring2 == plainstring3 == plainstring4 修改后:data=data[num][4].encode('utf-8') 成功运行
 

最新文章

  1. 【iCore3应用开发平台】发布 iCore3 应用开发平台寄存器说明
  2. onCreateOptionsMenu 和 onPrepareOptionsMenu 的区别
  3. docker: "build" requires 1 argument. See 'docker build --help'.
  4. POJ 2828 Buy Tickets (线段树 or 树状数组+二分)
  5. 【优先队列】【最近连STL都写不出来了/(ㄒoㄒ)/~~】hdu_5360/多校#6_1008
  6. 【数论,思路】HDU-5288;多校#1-1001
  7. 【CSS】Beginner2:Selectors, Properties, and Values
  8. Swift - 多线程实现方式(3) - Grand Central Dispatch(GCD)
  9. How to initialize a static const map in c++?
  10. Spider与OpenPyXL的结合
  11. java多线程之堵塞的应用
  12. Ubuntu 下超简单的安装指定版本的nodejs
  13. 1030 Travel Plan Dijkstra+dfs
  14. eclipse svn不能忽略文件及文件夹,ignore设置无效 ?
  15. 关于如何在本地IIS搭建网站
  16. UWP开发细节记录:WRL::ComPtr 的坑
  17. MVC修改视图的默认路径
  18. innerHTML与jquery里的html()区别介绍
  19. Microsoft.Web.Administration操作IIS7时的权限设置
  20. JS+Canvas的棋盘游戏和Java的动态结合

热门文章

  1. Maven学习总结(6)——Maven与Eclipse整合
  2. RDS for MySQL Online DDL 使用
  3. MFC 小知识总结四
  4. 深入理解Java和MySQL乱码问题
  5. kendo AutoComplete实现多筛选条件
  6. C++ 句柄类的原理以及设计
  7. Mac关闭Iphone更新系统iTunes强制自动备份文件
  8. Androlid入门之文件系统操作(三)文件读写
  9. spring:为javabean的集合对象注入属性值
  10. UESTC--1251--谕神的密码(贪心)