如何处理Python3.4 使用pymssql 乱码问题


Posted in Python onJanuary 08, 2016

在项目中发现这样一个问题:sqlserver数据库编码为gbk,使用python3.4+pymssql 查询,中文乱码,经过一番思考问题解决,下面把解决办法分享给大家:

conn = pymssql.connect(host="192.168.122.141", 
port=1433, 
user="myshop", 
password="oyf20140208HH", 
database="mySHOPCMStock", 
charset='utf8', 
as_dict=True) cur = conn.cursor()sql = "select top 10 [ID],[Name] from [User]"cur.execute(sql)list = cur.fetchall()for row in list: print(row["ID"],row["Name"].encode('latin-1').decode('gbk'))

接下来给大家介绍python 使用pymssql连接sql server数据库

#coding=utf-8 
#!/usr/bin/env python
#-------------------------------------------------------------------------------
# Name: pymssqlTest.py
# Purpose: 测试 pymssql库,该库到这里下载:http://www.lfd.uci.edu/~gohlke/pythonlibs/#pymssql
#
# Author: scott
#
# Created: 04/02/2012
#-------------------------------------------------------------------------------
import pymssql
class MSSQL:
"""
对pymssql的简单封装
pymssql库,该库到这里下载:http://www.lfd.uci.edu/~gohlke/pythonlibs/#pymssql
使用该库时,需要在Sql Server Configuration Manager里面将TCP/IP协议开启
用法:
"""
def __init__(self,host,user,pwd,db):
self.host = host
self.user = user
self.pwd = pwd
self.db = db
def __GetConnect(self):
"""
得到连接信息
返回: conn.cursor()
"""
if not self.db:
raise(NameError,"没有设置数据库信息")
self.conn = pymssql.connect(host=self.host,user=self.user,password=self.pwd,database=self.db,charset="utf8")
cur = self.conn.cursor()
if not cur:
raise(NameError,"连接数据库失败")
else:
return cur
def ExecQuery(self,sql):
"""
执行查询语句
返回的是一个包含tuple的list,list的元素是记录行,tuple的元素是每行记录的字段
调用示例:
ms = MSSQL(host="localhost",user="sa",pwd="123456",db="PythonWeiboStatistics")
resList = ms.ExecQuery("SELECT id,NickName FROM WeiBoUser")
for (id,NickName) in resList:
print str(id),NickName
"""
cur = self.__GetConnect()
cur.execute(sql)
resList = cur.fetchall()
#查询完毕后必须关闭连接
self.conn.close()
return resList
def ExecNonQuery(self,sql):
"""
执行非查询语句
调用示例:
cur = self.__GetConnect()
cur.execute(sql)
self.conn.commit()
self.conn.close()
"""
cur = self.__GetConnect()
cur.execute(sql)
self.conn.commit()
self.conn.close()
def main():
## ms = MSSQL(host="localhost",user="sa",pwd="123456",db="PythonWeiboStatistics")
## #返回的是一个包含tuple的list,list的元素是记录行,tuple的元素是每行记录的字段
## ms.ExecNonQuery("insert into WeiBoUser values('2','3')")
ms = MSSQL(host="localhost",user="sa",pwd="123456",db="PythonWeiboStatistics")
resList = ms.ExecQuery("SELECT id,weibocontent FROM WeiBo")
for (id,weibocontent) in resList:
print str(weibocontent).decode("utf8")
if __name__ == '__main__':
main()

三水点靠木提醒大家需要注意事项:

使用pymssql进行中文操作时候可能会出现中文乱码,我解决的方案是:

文件头加上 #coding=utf8

sql语句中有中文的时候进行encode

insertSql = "insert into WeiBo([UserId],[WeiBoContent],[PublishDate]) values(1,'测试','2012/2/1')".encode("utf8")

连接的时候加入charset设置信息

pymssql.connect(host=self.host,user=self.user,password=self.pwd,database=self.db,charset="utf8")

Python 相关文章推荐
python 判断一个进程是否存在
Apr 09 Python
python使用Queue在多个子进程间交换数据的方法
Apr 18 Python
详解python进行mp3格式判断
Dec 23 Python
Python实现简单的获取图片爬虫功能示例
Jul 12 Python
运动检测ViBe算法python实现代码
Jan 09 Python
Python+request+unittest实现接口测试框架集成实例
Mar 16 Python
浅谈Python中的作用域规则和闭包
Mar 20 Python
解决Python print输出不换行没空格的问题
Nov 14 Python
Python3.4学习笔记之类型判断,异常处理,终止程序操作小结
Mar 01 Python
python3 enum模块的应用实例详解
Aug 12 Python
TensorFlow tf.nn.softmax_cross_entropy_with_logits的用法
Apr 19 Python
python实现双链表
May 25 Python
Python argv用法详解
Jan 08 #Python
详解Python爬虫的基本写法
Jan 08 #Python
黑科技 Python脚本帮你找出微信上删除你好友的人
Jan 07 #Python
星球大战与Python之间的那些事
Jan 07 #Python
python高手之路python处理excel文件(方法汇总)
Jan 07 #Python
Python解析最简单的验证码
Jan 07 #Python
Python中http请求方法库汇总
Jan 06 #Python
You might like
中国收音机工业发展史
2021/03/02 无线电
FCKeditor添加自定义按钮
2008/03/27 PHP
PHP乱码问题,UTF-8乱码常见问题小结
2012/04/09 PHP
PHP读取CURL模拟登录时生成Cookie文件的方法
2014/11/04 PHP
新浪SAE搭建PHP项目教程
2015/01/28 PHP
thinkPHP实现递归循环栏目并按照树形结构无限极输出的方法
2016/05/19 PHP
Aster vs KG BO3 第一场2.19
2021/03/10 DOTA
JavaScript中:表达式和语句的区别[译]
2012/09/17 Javascript
js的匿名函数使用介绍
2013/12/11 Javascript
JS实现可自定义大小,可双击关闭的弹出层效果
2015/10/16 Javascript
AngularJS ng-bind-html 指令详解及实例代码
2016/07/30 Javascript
简单模拟node.js中require的加载机制
2016/10/27 Javascript
微信小程序 this和that详解及简单实例
2017/02/13 Javascript
利用jquery正则表达式在页面验证url网址输入是否正确
2017/04/04 jQuery
angularjs2 ng2 密码隐藏显示的实例代码
2017/08/01 Javascript
React如何将组件渲染到指定DOM节点详解
2017/09/08 Javascript
Angular4实现鼠标悬停3d倾斜效果
2017/10/25 Javascript
JavaScript登录验证基础教程
2017/11/01 Javascript
利用SpringMVC过滤器解决vue跨域请求的问题
2018/02/10 Javascript
angular动态表单制作
2018/02/23 Javascript
[01:13:08]2018DOTA2亚洲邀请赛4.6 淘汰赛 mineski vs LGD 第二场
2018/04/10 DOTA
python在Windows下安装setuptools(easy_install工具)步骤详解
2016/07/01 Python
Python合并多个Excel数据的方法
2018/07/16 Python
python3的输入方式及多组输入方法
2018/10/17 Python
对python周期性定时器的示例详解
2019/02/19 Python
使用virtualenv创建Python环境及PyQT5环境配置的方法
2019/09/10 Python
kafka-python 获取topic lag值方式
2019/12/23 Python
python实现吃苹果小游戏
2020/03/21 Python
你需要学会的8个Python列表技巧
2020/06/24 Python
房地产员工找工作的自我评价
2013/11/15 职场文书
促销活动总结
2014/04/28 职场文书
伦敦奥运会口号
2014/06/13 职场文书
答谢词范文
2015/01/05 职场文书
二手房购房意向书
2015/05/09 职场文书
田径运动会广播稿
2015/08/19 职场文书
SpringMVC 整合SSM框架详解
2021/08/30 Java/Android