设为首页 收藏本站
查看: 1897|回复: 0

[经验分享] python中处理中文编码问题

[复制链接]

尚未签到

发表于 2018-8-10 09:05:37 | 显示全部楼层 |阅读模式
  今天在尝试Python的CGI模块时遇到中文字符不能正确显示的问题,很郁闷.
  在网上仔细找了找,终于解决了这个问题,现在将解决方法陈述如下,以防下次失误.
  页面源代码如下
  #-*- coding: utf8 -*-
  import cgitb , cgi
  cgitb.enable()
  form = cgi.FieldStorage()
  if (form.has_key("name") and form.has_key("addr")):
  print "<p>name:", form["name"].value
  print "<p>addr:", form["addr"].value
  [这里仅仅测试addr参数为中文]接收Ascii字符时运行良好,但是接收中文字符时显示乱码,
  浏览器切换到GB2312编码时,可以正常显示,但是个人要求它成为UTF-8编码显示
  改成 print "<p>addr:", form["addr"].value.encode('utf-8')  就报如下错误:
  UnicodeDecodeError: 'utf8' codec can't decode bytes in position 0-1: invalid data
  在参阅了http://blog.chinaunix.net/u2/68206/showart_668359.html 后终于理解,
  Python 里面的编码和解码也就是 unicode 和 str 这两种形式的相互转化。
  编码是 unicode -> str,相反的,解码就 是 str -> unicode。
  剩下的问题就是确定何时需要进行编码或者解码了.关于文件开头的"编码指示",
  也就是 # -*- coding: -*- 这个语句。Python 默认脚本文件都是 UTF-8 编码的,
  当文件中有非 UTF-8 编码范围内的字符的时候就要使用"编码指示"来修正.
  关于 sys.defaultencoding,这个在解码没有明确指明解码方式的时候使用。
  比如我有如下代码:
  #! /usr/bin/env python
  # -*- coding: utf-8 -*-
  s = '中文'  # 注意这里的 str 是 str 类型的,而不是 unicode
  s.encode('gb18030')
  这句代码将 s 重新编码为 gb18030 的格式,即进行 unicode -> str 的转换。
  因为 s 本身就是 str 类型的,因此 Python 会自动的先将 s 解码为 unicode ,
  然后再编码成 gb18030。因为解码是python自动进行的,我们没有指明解码方式,
  python 就会使用 sys.defaultencoding 指明的方式来解码。
  很多情况下 sys.defaultencoding 是 ANSCII,如果 s 不是这个类型就会出错。
  拿上面的情况来说,我的 sys.defaultencoding 是 anscii,
  而 s 的编码方式和文件的编码方式一致,是 utf8 的,所以出错了:
  UnicodeDecodeError: 'ascii' codec can't decode byte 0xe4 in position
  0: ordinal not in range(128)
  对于这种情况,我们有两种方法来改正错误:
  一是明确的指示出 s 的编码方式
  #! /usr/bin/env python
  # -*- coding: utf-8 -*-
  s = '中文'
  s.decode('utf-8').encode('gb18030')
  二是更改 sys.defaultencoding 为文件的编码方式
  #! /usr/bin/env python
  # -*- coding: utf-8 -*-
  import sys
  reload(sys) # Python2.5 初始化后会删除 sys.setdefaultencoding 这个方法,我们需要重新载入
  sys.setdefaultencoding('utf-8')
  str = '中文'
  str.encode('gb18030')
  看完之后,改成这样
  print "<p>addr:", form["addr"].value.decode('gb2312').encode('utf-8')
  成功通过.
  我总结一下为什么要这么写的原因:
  1. 当取回来的数据与你当前脚本中声明的编码不一致时就要做编码转换
  2.在编码转换时首先要将该数据以自身编码的格式换成unicode码,再将这个unicode按utf8编码
  3.为什么我的浏览器会传回gb2312的编码数据到服务器,这应该和客户端的系统编码有关系
  这里顺便转载一下,关于Python 操作Mysql的中文问题:
  Python操作MySQL以及中文乱码的问题
  下面几个措施,保证MySQL的输出没有乱麻:
  1 Python文件设置编码 utf-8 (文件前面加上 #encoding=utf-8)
  2 MySQL数据库
  3 Python连接MySQL是加上参数 charset=utf8
  4 设置Python的默认编码为 utf-8 (sys.setdefaultencoding(utf-8)
  Java代码
  #encoding=utf-8
  import sys
  import MySQLdb
  reload(sys)
  sys.setdefaultencoding('utf-8')
  db=MySQLdb.connect(user='root',charset='utf8')
  cur=db.cursor()
  cur.execute('use mydb')
  cur.execute('select * from mytb limit 100')
  f=file("/home/user/work/tem.txt",'w')
  for i in cur.fetchall():
  f.write(str(i))
  f.write(" ")
  f.close()
  cur.close()

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-549479-1-1.html 上篇帖子: python单例模式 下篇帖子: python pwd和grp模块
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表