本文目录一览:
python中文乱码解决
windows下的文件路径,cmd窗口等默认编码都是gbk 但在windows下编写python程序的时候,我们一般采用的编码是utf-8 二者不一致是导致乱码的根本原因! 在pycharm下,为了中文不乱码,那么需要注意一下几个方面: 一、每一个源程序文件头部,需要加上
#-*-coding:utf-8;-*-
这样就没有乱码了
python3连接MSSQL数据库 中文乱码怎么解决
以前用php连mssqy时也经常出现中文乱码(中文变问号)的问题,那时就明白是编码没设置好导航,现在的Python连mssql数据库也同样出现这问题,问题一样,解决的办法当然也会相似,现在我们来看看解决方法。 python一直对中文支持的不好,最近老遇到编码问题,而且几乎没有通用的方案来解决这个问题,但是对常见的方法都试过之后,发现还是可以解决的,下面总结了常用的支持中文的编码问题(这些方法中可能其中一个就能解决问题,也可能是多个组合)。 (1)、首先,要保证文件的开头要加上编码设置来说明文件的编码 代码如下
#encoding=utf-8
(2)、然后,在连接数据的连接参数里加上字符集说明查询出的结果的编码,这个不加的后果可能是查询出的汉字字符都是问号 代码如下
conn = pymssql.connect(server='.', user='', password='', database='MyTest', charset='utf8')
(3)、设置python系统的默认编码(对于文件来说,这招几乎屡试不爽,呵呵~~) 代码如下
import sys
reload(sys)
sys.setdefaultencoding('utf8')
注意:上述编码是“utf8”,而不是“utf-8”,我也没弄明白,大部分情况下,这个无所谓的,但是这里我试了必须要是“utf8” 一个简单的完整的python连接mssqlserver的例子如下(得安装pymssql包):
#encoding:utf8
import sys
reload(sys)
sys.setdefaultencoding('utf8')
import pymssql
try:
conn = pymssql.connect(server='.', user='', password='', database='MyTest', charset='utf8')
sql = "select * from UserInfo"
cur = conn.cursor()
cur.execute(sql)
data = cur.fetchall()
conn.close()
print data
except Exception, e:
print e
运行结果如下:
[(u'20093501', u'xb9xf9xbexb8', u'u7537', 35, u'xb4xf0xcfxc0'),
(u'20093502', u'xbbxc6xc8xd8', u'u5973', 34, u'xc3xc0xc5xae'),
(u'20093503', u'xc1xeexbaxfcxb3xe5', u'u7537', 25, u'2Bxc7xe0xc4xea'),
(u'20093504', u'xc8xcexd3xafxd3xaf', u'u5973', 24, u'xc6xafxc1xc1')]
虽然摆脱了问号和乱码的困扰,但这仍不是我们想要的结果,但这个确实是正确的,因为结果是utf8编码。这个现象确实诡异,请教了许多高手,得知,最好的结果就是逐个字段查询,才能显示中文,整个查询的话,会以utf8的格式显示出来。
上述代码中第14行data是整个查询的结果,如果指定某个具体的字段,如print data[0][2]
(表示取查询结果的第一行第三列的字段的值),则会输出中文。
其实不仅仅是mssqlserver数据库,mysql(需下载MySQLdb包)、sqllite(python自带的文件数据库)、mongodb(需下载PyMongo包)等或者是普通文本文件也是类似的解决方案。
python查mysql数据库 返回结果的中文乱码
这个不是乱码,这是 unicode 字符串在内存中的形式,python 在命令行界面输出的数据,如果不是ASCII码,则会以十六进制形式输出。需要输出看见中文的话,代码如下。
# 利用第三方库uniout,如果没有就安装:pip install uniout
import uniout
listnine = ['梨', '橘子', '苹果', '香蕉']
print listnine
python 向SQL Server2008插入中文数据乱码
- 中文乱码问题: (1)、文件头加上
# -*- coding:utf-8 -*-
或者
#coding=utf8
(2)、pymssql.connect连接串中charset是要跟你数据库的编码一样,如果是数据库是gb2312,则写charset='gb2312'
。
(3)、读取数据时需要decode('utf-8')
,写入数据时需要encode('utf-8')
,这样就可以避免中文乱码或报错问题。
做个搬运工,转载自网页链接,我用方法2搞定了汉字查询输出。