免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 4954 | 回复: 6
打印 上一主题 下一主题

中文输出乱码 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-07-15 16:28 |只看该作者 |倒序浏览
程序从mysql数据库里查询出的中文数据输出是乱码,我的数据库编码是utf-8编码,在print是我用decode转成utf-8输出还是乱码,试了gb2312还是乱码,请问怎么才能正常print呢?谢谢!

论坛徽章:
46
15-16赛季CBA联赛之四川
日期:2018-03-27 11:59:132015年亚洲杯之沙特阿拉伯
日期:2015-04-11 17:31:45天蝎座
日期:2015-03-25 16:56:49双鱼座
日期:2015-03-25 16:56:30摩羯座
日期:2015-03-25 16:56:09巳蛇
日期:2015-03-25 16:55:30卯兔
日期:2015-03-25 16:54:29子鼠
日期:2015-03-25 16:53:59申猴
日期:2015-03-25 16:53:29寅虎
日期:2015-03-25 16:52:29羊年新春福章
日期:2015-03-25 16:51:212015亚冠之布里斯班狮吼
日期:2015-07-13 10:44:56
2 [报告]
发表于 2011-07-15 16:30 |只看该作者
先 decode utf8 再按终端的编码类型如果需要再转下码试试

论坛徽章:
0
3 [报告]
发表于 2011-07-15 17:00 |只看该作者
我的终端编码也是utf-8,我用这个试过也是不行,encode('utf-8',decode('utf-8','你好'));gb2312也试过。

论坛徽章:
0
4 [报告]
发表于 2011-07-15 18:40 |只看该作者
哎, 乱码的问题就没断过.

版主给出个faq吧.


论坛徽章:
0
5 [报告]
发表于 2011-07-15 19:23 |只看该作者
是不是直接 decode 然后 print 就可以?

论坛徽章:
0
6 [报告]
发表于 2011-07-15 19:45 |只看该作者
多字节字符, 一般是用unicode来表示, 一个字符有一个代码点.

至于这个代码点怎么表示, 就看使用哪个字符编码方式了. 比如有utf8, gbk等.

对于楼主的问题, 首先你用mysql客户端/phpmyadmin看来出来的内容是不是正常的? 这样确认mysql里的数据是按你表中指定的编码方式编码的.

然后, 你用perl取出数据, 这时要看你dbi中client encoding是什么. 如果是utf8,则你取出来的utf8;这个值是二进制字节流;

这时, 要看你的系统了. 这个输出的时候, 字符编码要跟你的系统的编码一样, 否则就需要转换为操作系统的字符集. 比如中文的windows是gbk的, *nix系统是locale命令输出的字符集(这个操作系统指的是perl运行环境所在的操作系统)

print的字符与你的操作系统的时候集一样的, 这时走过了99%. 如果你是远程连接的, 如用的putty/securecrt, 则要看你的putty/securecrt客户端中设置的字符集是否与你远程的服务器的字符集相同.

核对一下吧 , 字符集乱码的原因是非常多的.

论坛徽章:
0
7 [报告]
发表于 2011-07-18 09:41 |只看该作者
解决了,在查询之前执行这个设置输出编码就可以正常显示了。set character_set_results='utf8'。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP