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问题
无法使用Django restfram生成PDF
2 回答
无法使用Django Rest框架发送压缩的gzip数据
7 回答
无法使用Django rest框架进行身份验证(请求用户=匿名用户)
10 回答
无法使用Django、Python和JavaScrip触发onclick函数
9 回答
无法使用Django.views.generic.View保存表单
4 回答
无法使用Django(python 2.7,OS X 10.11.1)
1 回答
无法使用Django/mongoengine连接到MongoDB(身份验证失败)
8 回答
无法使用Django\u mssql\u后端迁移到外部hos
6 回答
无法使用Django&Python3.4连接到MySql
2 回答
无法使用Django+nginx上载媒体文件
10 回答
无法使用Django1.6导入名称模式
8 回答
无法使用Django1.7和mongodb登录管理站点
3 回答
无法使用Djangoadmin创建项目,进程使用了错误的路径,因为我事先安装了错误的Python
3 回答
无法使用Djangockedi验证CBV中的字段
9 回答
无法使用Djangocketditor上载图像(错误400)
5 回答
无法使用Djangocron进行函数调用
7 回答
无法使用Djangofiler djang上载文件
8 回答
无法使用Djangokronos
6 回答
无法使用Djangomssql provid
8 回答
无法使用Djangomssql连接到带有Django 1.11的MS SQL Server 2016
5 回答