Python中文
首页
教程
问答
标签
搜索
登录
注册
Python:UnicodeEncodeError:“latin-1”编解码器无法对ch进行编码
回答此问题可获得
20
贡献值,回答如果被采纳可获得
50
分。
<p>我在一个场景中调用api,并根据api的结果为api中的每条记录调用数据库。我的api调用返回字符串,当我对api返回的项进行数据库调用时,对于某些元素,我得到以下错误。</p> <pre><code>Traceback (most recent call last): File "TopLevelCategories.py", line 267, in <module> cursor.execute(categoryQuery, {'title': startCategory}); File "/opt/ts/python/2.7/lib/python2.7/site-packages/MySQLdb/cursors.py", line 158, in execute query = query % db.literal(args) File "/opt/ts/python/2.7/lib/python2.7/site-packages/MySQLdb/connections.py", line 265, in literal return self.escape(o, self.encoders) File "/opt/ts/python/2.7/lib/python2.7/site-packages/MySQLdb/connections.py", line 203, in unicode_literal return db.literal(u.encode(unicode_literal.charset)) UnicodeEncodeError: 'latin-1' codec can't encode character u'\u2013' in position 3: ordinal not in range(256) </code></pre> <p>上述错误所指的代码段是:</p> <pre><code> ... for startCategory in value[0]: categoryResults = [] try: categoryRow = "" baseCategoryTree[startCategory] = [] #print categoryQuery % {'title': startCategory}; cursor.execute(categoryQuery, {'title': startCategory}) #unicode issue done = False cont... </code></pre> <p>在做了一些google搜索之后,我在命令行上尝试了以下内容,以了解发生了什么。。。</p> <pre><code>>>> import sys >>> u'\u2013'.encode('iso-8859-1') Traceback (most recent call last): File "<stdin>", line 1, in <module> UnicodeEncodeError: 'latin-1' codec can't encode character u'\u2013' in position 0: ordinal not in range(256) >>> u'\u2013'.encode('cp1252') '\x96' >>> '\u2013'.encode('cp1252') '\\u2013' >>> u'\u2013'.encode('cp1252') '\x96' </code></pre> <p>但我不知道怎样才能解决这个问题。我也不知道背后的理论是什么,如果我能得到一些解释,我在上面尝试过。</p>
0 条评论
分类:
Python问答
请先
登录
后评论
默认排序
时间排序
1 个回答
匿名
1天前
擅长:python、mysql、java
<p>unicode字符u'\02013'是“短划线”。它包含在Windows-1252(cp1252)字符集(编码为x96)中,但不包含在拉丁语-1(iso-8859-1)字符集中。Windows-1252字符集在x80-x9f区域中定义了更多字符,其中包括en破折号。</p> <p>解决方案是选择一个不同于拉丁文-1的目标字符集,比如Windows-1252或UTF-8,或者用一个简单的“-”替换en-dash。</p>
请先
登录
后评论
针对此问题:
更多的回答
关注
89
关注
收藏
1
收藏,
216
浏览
网友 提问于 2天前
相关Python问题
尽管Python中的所有内容都是引用,为什么Python导师在没有指针的列表中绘制字符串和整数?
3 回答
尽管python中的表达式为false,但循环仍在运行
8 回答
尽管python代码正确,但从nifi ExecuteScript处理器获取语法错误
4 回答
尽管Python在Neovim中工作得很好,但插件不能识别Neovim中的Python主机
8 回答
尽管python字典包含了大量的条目,但它并没有增长
9 回答
尽管python说模块存在,为什么我会得到这个消息?
4 回答
尽管setuptools和控制盘是最新的,但无法识别singleversionexternallymanaged
4 回答
尽管stdout和stderr重定向,但未捕获错误消息
6 回答
尽管Tensorboard的事件太大,但Tensorboard的步骤太少了
5 回答
尽管tkinter上的变量已更改,但显示未更改
6 回答
尽管try/except使用Python进行单元测试时出现断言错误
7 回答
尽管URL是sam,但仍会抛出“达到最大重定向”
6 回答
尽管url有效,Pandas仍读取url的\u csv错误
4 回答
尽管while中存在时间延迟,但LINUX线程的CPU利用率为100%(1)
6 回答
尽管x0在范围内,Scipy优化仍会引发ValueError
2 回答
尽管xpath正确,但使用selenium单击链接仍不起作用
10 回答
尽管下载了ffmpeg并设置了路径变量python,但没有后端错误
9 回答
尽管下载了i,但找不到型号“fr”
1 回答
尽管下载了plotnine包,但未获取名为“plotnine”的模块时出错
4 回答
尽管为所有行指定了权重,网格(0)仍不起作用
3 回答