在Python 3中,我从一个URL请求一个json文档。
response = urllib.request.urlopen(request)
response
对象是具有read
和readline
方法的类似文件的对象。通常,可以使用以文本模式打开的文件创建JSON对象。
obj = json.load(fp)
我想做的是:
obj = json.load(response)
但这不起作用,因为urlopen以二进制模式返回文件对象。
解决办法当然是:
str_response = response.read().decode('utf-8')
obj = json.loads(str_response)
但这感觉很糟糕。。。
有没有更好的方法可以将bytes文件对象转换为string文件对象?或者,我是否缺少任何参数,以便urlopen
或json.load
给出编码?
HTTP发送字节。如果所讨论的资源是文本,则字符编码通常由内容类型HTTP头或其他机制(RFC、HTML
meta http-equiv
,…)指定。urllib
应该知道如何将字节编码为字符串,但这太幼稚了,它是一个功能严重不足的非Pythonic库。Dive Into Python 3提供了有关情况的概述。
你的“变通”很好,虽然感觉不对,但这是正确的方法。
我认为这个问题是最好的答案:)
Python出色的标准库来拯救
同时适用于py2和py3。
文件:Python 2,Python3
相关问题 更多 >
编程相关推荐