2

UTF-8でエンコードされたHTTP応答の結果を取得する次のケースがあります。応答コンテンツ(JSON)をロードしたい。json.loadsただし、最終的なリストを取得するために2を実行する必要がある理由はわかりません。

result = urllib2.urlopen(req).read()
print result, type(result)
#=> "[{\"pk\": 66, \"model\": \"core.job\", \"fields\": {\"customer\": 1, \"created_ts\": \"2010-03-06 06:33:36\", \"log\": 66, \"process\": 1, \"ended_ts\": null, \"state\": \"PENDING\", \"started_ts\": null}}]" <type 'str'>
ret = json.loads(result)
print ret , type(ret)
#=> [{"pk": 66, "model": "core.job", "fields": {"customer": 1, "created_ts": "2010-03-06 06:33:36", "log": 66, "process": 1, "ended_ts": null, "state": "PENDING", "started_ts": null}}] <type 'unicode'>
ret = json.loads(ret)
print ret , type(ret)
#=>[{u'pk': 66, u'model': u'core.job', u'fields': {u'customer': 1, u'created_ts': u'2010-03-06 06:33:36', u'log': 66, u'process': 1, u'ended_ts': None, u'state': u'PENDING', u'started_ts': None}}] <type 'list'>

何か案は?

4

1 に答える 1

3

repr()JSON 文字列自体ではなく、JSON 文字列の が返されているようです。そのため、サーバー上で何かが壊れています。

于 2010-03-06T13:04:48.233 に答える