Python中文
首页
教程
问答
标签
搜索
登录
注册
python字节字符串编码和解码
回答此问题可获得
20
贡献值,回答如果被采纳可获得
50
分。
<p>我正在尝试将包含非ascii字符的传入字节字符串转换为有效的utf-8字符串,以便可以将is转储为json。</p> <pre><code>b = '\x80' u8 = b.encode('utf-8') j = json.dumps(u8) </code></pre> <p>我希望j是'\xc2\x80',但是我得到了:</p> <pre><code>UnicodeDecodeError: 'ascii' codec can't decode byte 0x80 in position 0: ordinal not in range(128) </code></pre> <p>在我的情况下,“b”来自mysql,通过google协议缓冲区,并由一些blob数据填充。</p> <p>有什么想法吗?</p> <p>编辑: 我有以太网帧作为blob存储在一个mysql表中(请大家注意,不要讨论表中为什么有数据包)。表排序规则是utf-8,db层(sqlalchemy,non-orm)正在获取数据并创建结构(google protocol buffers),将blob存储为python“str”。在某些情况下,我直接使用协议缓冲区而没有任何问题。在其他情况下,我需要通过json公开相同的数据。我注意到,当json.dumps()执行其操作时,'\x80'可以替换为无效的unicode字符(\ufffd iirc)</p>
0 条评论
分类:
Python问答
请先
登录
后评论
默认排序
时间排序
1 个回答
匿名
1天前
擅长:python、mysql、java
<p>使用<code>b.decode('name of source encoding')</code>获取unicode版本。当我学会这一点时,我感到很惊讶。例如:</p> <pre><code>In [123]: 'foo'.decode('latin-1') Out[123]: u'foo' </code></pre>
请先
登录
后评论
针对此问题:
更多的回答
关注
89
关注
收藏
1
收藏,
216
浏览
网友 提问于 2天前
相关Python问题
plt.savefig不会覆盖现有文件
10 回答
plt.savefig不保存图像
7 回答
plt.savefig在jupyter笔记本中不起作用
6 回答
plt.savefig在从另一个fi调用时停止工作
3 回答
plt.savefig在调用plt.show之前保存空数字
5 回答
plt.save不创建png文件
2 回答
plt.scatter overlay分类数据帧列
7 回答
Plt.Scatter:如何添加title、xlabel和ylab
3 回答
plt.scatter()绘图与Matplotlib中的plt.plot()绘图类似
2 回答
plt.scatter错误'NoneType'对象在成功运行后没有属性'sqrt'
6 回答
plt.set_title()中的标题字符串有误
5 回答
plt.show()
8 回答
plt.show()不在Jupyter笔记本上渲染任何内容
8 回答
plt.show()不打印plt.plot only plt.scatter
6 回答
plt.show()不显示三维散射图像
7 回答
plt.show()不显示任何内容
5 回答
plt.show()不显示数据,而是保留它供下一个图表使用(spyder)
7 回答
plt.show()使终端挂起
1 回答
plt.show()无法使用此代码
7 回答
plt.show()没有打开新的图形风
8 回答