在项目中发现这样一个问题: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")
内容乱码是采集过程中很常见的问题。 出现乱码的问题很多,解决方法也不尽相同,要视具体情况而定,以下几种乱码解决方案仅供参考。 一.使用QueryList内置的乱码解决方案 1.使用编码转换插件,设置输入输出编码 $html =<<<STR <div> <p>这是内容</p> </div> STR; $rule = [ 'content' => ['div>p:last','text
经常会有短暂的组织混乱,比如解雇,收购,IPO,新雇佣,等等。对每个人来说这都是令人不安的,但可能对于那些将自尊建立在能力而非位置上的程序员来讲,这种不安不会那么严重。组织混乱对程序员来讲是锻炼他们的魔力的好机会。因为这是一个集体秘密,在最后我会有所保留。如果你不是一个程序员,就不要再读下去了。 工程师有能力创造与维持。 非工程师可以安排人们,但,在典型的软件公司,如果没有程序员的话,他们不能创造
本文向大家介绍java web过滤器处理乱码,包括了java web过滤器处理乱码的使用技巧和注意事项,需要的朋友参考一下 我们在servlet页面中读取前台的数据时 经常会出现乱码问题 而自己每次都要在servlet中使用 来进行编码的转换 会很麻烦 所以使用过滤器 我们可以避免这些重复的工作 web.xml配置 Filter 这样的话 在servlet里面读取到的数据就不会出现乱码的情况
本文向大家介绍php上传中文文件名乱码问题处理方案,包括了php上传中文文件名乱码问题处理方案的使用技巧和注意事项,需要的朋友参考一下 php上传文件是最最基础的一个技术点,但是深入进去也有不少问题需要解决,这不,上传中文文件后,文件名变成了乱码。 下面是问题代码,很简单: 1.问题代码 html部分: php部分: 上传了一个文件名为“测试数据.txt”的文件,oh ho,文件是传上去了,但
我遇到了这个问题: 您将获得一个由 n 个不同的整数 a0、a1、. . .an−1.在每次迭代中,您选择最大数字并将其删除,取消最大数字的成本是其左侧的数字数。重复此 n 次。给定ai实现一个O(n log n)算法来计算n次迭代的总成本。 我知道我们必须使用BST来解决这个问题,因为它是O(N log N),但是,我不知道该怎么办。 我想我可以在hashMap中存储值和索引,当删除完成后,我们
问题内容: 我搜索了有关Java和编码的信息,但没有找到说明如何处理编码和解码字符串时Java出现的公共问题的资源。关于单个错误,有很多特定的问题,但是我没有找到有关该问题的广泛答复/参考指南。主要问题是: 什么是字符串编码? 为什么在Java中我可以读取带有错误字符的文件? 为什么在处理xml时出现y字节UTF-8序列异常的无效字节x?主要原因是什么,以及如何避免它们? 问题答案: 由于Stac