免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 4209 | 回复: 0

解决python读mysql中文繁体乱码问题 [复制链接]

论坛徽章:
0
发表于 2010-01-20 14:40 |显示全部楼层
这几天出现了一个怪现象,写了一个用python访问mysql的数据库程序。在我的arch下面运行一段程序没有字符乱码问题,但是在ubuntu下面运行的时候,出现的繁体中文乱码,最后,终于找到了解决方法。首先,发现ubuntu没有中文语言包,所以就先将中文语言包(包括简体和繁体)都安装上,可是运行程序还是乱码,后来在想,是不是我在写文件的时候,有乱码,可是再往前推,发现读数据库的时候,明明数据库里面数据是正常繁体中文显示,但是在终端里面却仍是乱码,最后,在MySQLdb.connect的时候,多加了一个参数, charset="utf8",好了,读出来的结果是正确的。我想原因就在于这个点上了。另外,因为要将结果写在一个文件中,发现提示错误说是:UnicodeEncodeError: 'ascii' codec can't encode characters in position 242-244: ordinal not in range(128)而这一行就是简单的将文件写入的语句,格式为fn.write("%s\n",var),按照提示,应该是这个var变量太长了,超过128个字符,最后用这样的形式就可以了:fp_csv.write(new_row.encode('utf-8') + "\n")好了,这个问题伤脑盘的问题终于可以告以段落了。
               
               
               
               

本文来自ChinaUnix博客,如果查看原文请点:http://blog.chinaunix.net/u/15586/showart_2154810.html
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP