您的位置:

python数据库中文乱码(python读取oracle数据库中文乱码)

本文目录一览:

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'xb4xf3xcfxc0'),

(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')]

[Finished

in

0.2s]

虽然摆脱了问号和乱码的困扰,但这仍不是我们想要的结果,但这个确实是正确的,因为结果是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、中文乱码问题:

(1)、文件头加上#

-*-

coding:utf-8

-*-

或者

#coding=utf8

(2)、pymssql.connect连接串中charset是要跟你数据库的编码一样,如果是数据库是gb2312

,则写charset='gb2312'。

(3)、读取数据时需要decode('utf-8'),写入数据时需要encode('utf-8'),这样就可以避免中文乱码或报错问题。

做个搬运工,转载自网页链接,我用方法2搞定了汉字查询输出。

python数据库中文乱码(python读取oracle数据

2022-11-12
读取mysql数据库乱码(mysql读取中文乱码)

2022-11-13
python爬取乱码,python读取中文乱码

2022-11-18
从数据库取中文到前台js是乱码(java读取数据库中文部分乱

本文目录一览: 1、js中文乱码怎么解决? 2、我用js调用一段数据库里的文字 现示乱码 3、为什么 数据库提取中文是乱码? 4、解决:JSP页面取出数据库中的中文出现乱码 5、js中文乱码 6、js

2023-12-08
phpmsql乱码,php数据库中文乱码

2022-11-30
Python中文乱码

2023-05-10
mysql数据库中文乱码的问题(MySQL数据库中文乱码)

2022-11-08
保存到mysql数据库中文乱码(mysql数据库导出中文乱码

2022-11-15
读取mysql数据库数据乱码(读取mysql数据库数据乱码怎

2022-11-10
java服务之间传数据乱码,java连接数据库中文乱码

2022-11-30
java读取中文xml乱码(java解析xml中文乱码)

2022-11-15
python生成csv文件乱码,csv文件下载乱码

2022-11-20
mysqlphp中文数据库乱码(mysql数据库中文乱码如何

2022-11-10
连接mysql数据库中文乱码,数据库连接中文乱码怎么解决

2022-11-19
mysql数据库的中文乱码,mysql数据库的中文乱码怎么解

2022-11-23
编码mysql乱码数据库,数据库数据乱码

2022-11-21
python文件浏览器中文乱码(python中中文乱码)

2022-11-10
phpcms数据库乱码,php数据库中文乱码

2022-12-01
本地的mysql数据库乱码处理,mysql数据表中文乱码

2022-11-19
java连接mysql乱码,jdbc连接mysql数据库中文

2022-11-22