Python中文
首页
教程
问答
标签
搜索
登录
注册
从pyodbc到MS-SQL的编码调用
回答此问题可获得
20
贡献值,回答如果被采纳可获得
50
分。
<p>我使用pyodbc模块通过SQL Alchemy连接到MS-SQL服务器。一切似乎都很好,直到我开始有问题的编码。一些非ascii字符将被替换为“?”</p> <p>数据库有一个排序规则“Latin1_General_CI_AS”(我也检查了特定字段,它们保持相同的排序规则)。我开始在<code>create_engine</code>的调用中选择编码“latin1”,这似乎适用于西欧字符(如法语或西班牙语,如<code>é</code>),但不适用于东欧字符。具体来说,我对字符<code>ć</code>有问题</p> <p>我一直在尝试选择其他编码<a href="http://docs.python.org/library/codecs.html#standard-encodings" rel="nofollow noreferrer">as stated on Python documentation</a>,特别是微软的编码,比如<code>cp1250</code>和<code>cp1252</code>,但我一直面临同样的问题。</p> <p>有人知道如何解决这些分歧吗?排序规则“Latin1_General_CI_AS”是否与Python编码相同?</p> <p>我当前连接的代码如下</p> <pre><code>for sqlalchemy import * def connect(): return pyodbc.connect('DSN=database;UID=uid;PWD=password') engine = create_engine('mssql://', creator=connect, encoding='latin1') connection = engine.connect() </code></pre> <p>澄清和评论:</p> <ul> <li>从数据库检索信息时会出现此问题。我不需要储存任何东西。</li> <li>一开始我没有指定编码,结果是,每当在数据库上遇到非ascii字符时,pyodbc就会引发UnicodeDecodeError。我更正了使用“latin1”作为编码,但这并不能解决所有字符的问题。</li> <li>我承认服务器不在latin1上,评论不正确。我一直在检查数据库排序规则和特定字段排序规则,似乎都在“Latin1_General_ciu AS”中,那么,如何存储<code>ć</code>?也许我没有正确理解校勘。</li> <li>我稍微修正了一下这个问题,特别是,我尝试了比<code>latin1</code>更多的编码,还有<code>cp1250</code>和<code>cp1252</code>(根据msdn的说法,这显然是用于“拉丁语通用词”的编码)</li> </ul> <p>更新:</p> <p>好,按照这些步骤,我得到DB使用的编码似乎是cp1252:<a href="http://bytes.com/topic/sql-server/answers/142972-characters-encoding" rel="nofollow noreferrer">http://bytes.com/topic/sql-server/answers/142972-characters-encoding</a> 无论如何,这似乎是一个坏的假设,反映在答案上。</p> <p>更新2: 无论如何,在正确配置odbc驱动程序之后,我不需要在Python代码上指定编码。</p>
0 条评论
分类:
Python问答
请先
登录
后评论
默认排序
时间排序
1 个回答
匿名
1天前
擅长:python、mysql、java
<p>您应该停止使用代码页并切换到Unicode。这是解决这类问题的唯一方法。</p>
请先
登录
后评论
针对此问题:
更多的回答
关注
89
关注
收藏
1
收藏,
216
浏览
网友 提问于 2天前
相关Python问题
为什么在使用strptime时会出现未进行转换的数据错误?
6 回答
为什么在使用strptim时会出现这个datetime日期错误
5 回答
为什么在使用StyleFrame时索引列的标题不显示sf.至excel()?
1 回答
为什么在使用sum()函数时会发生“int”对象不可调用的错误?
5 回答
为什么在使用sympy.dsolve时会得到“'list'对象没有属性'func'”?
10 回答
为什么在使用tabla时会得到一个空的数据帧?
2 回答
为什么在使用tensorboard时需要add_graph()的第二个参数?
3 回答
为什么在使用TensorFlow Lite转换YOLOv4时,推断时间/大小没有改进?有什么可能的改进吗?
7 回答
为什么在使用Tensorflow加载训练批时会出现内存泄漏?
1 回答
为什么在使用tensorflow时会收到警告/错误(使用函数API,但未实现错误)
3 回答
为什么在使用tetpyclient发出POST请求时出现403错误?
5 回答
为什么在使用TextBlob时会出现HTTP错误?
10 回答
为什么在使用TFIDF时出现错误“IndexError:list index out of range”pyspark.ml.feature?
5 回答
为什么在使用timedelta格式化之后,我在python中的日期是错误的?
1 回答
为什么在使用timeit或exec函数时,函数中的变量不会在提供的全局命名空间中搜索?
6 回答
为什么在使用tkinter时不能使用复选框?
1 回答
为什么在使用todoistpythonapi时会返回这个奇怪的ID?
6 回答
为什么在使用TQM时,在调整图像大小时,处理时间会有很大的差异?
8 回答
为什么在使用Tweepy下载用户时间线时收到错误消息
4 回答
为什么在使用twitter帐户登录Django应用程序时重定向127.0.0.1:8000?
9 回答