2016-04-22 22 views
0

私はjson.loads(json_string)をしようとすると、それはそれは私がJSONをしようとすると、文字列python3がこのjson文字列をロードしないのはなぜですか?

でなければならない、バイト配列することはできませんprint(str(json_string))出力

を言うている文字列

b'{"nonce":"820346305172674795","hash":"CF9558F1AC5AA3F4F3D598BAD50D8E0FD15E536A98095C01AD1BA962BDF342D0E37CF6ED595758B3217CA1986238B10EB729D5C5EBCE1523B41328365E936DBE","encryptedMessage":"ABF47CA76B72388B3CA8F4BF95D199D02835C5AED546CC6A6A35663C312093DB05E3765A00211242770136D7F2391A2A69CCA28B4D9695","signature":"09036C211B6386AD0B1D7EDA14AE4C4C77721916C9AF48E7141049E2773098665776AA4B7CC6E12B4B5BD1FBB3B590F41C6254313BAEBA9293D87769F1A4200468747470733A2F2F3139322E3136382E312E38343A353030302F746F67676C655F646F6F722431"}' 

を持っています。

+3

'json.load(json_string.decode( 'UTF-8'))'してみてください。先頭の「b」はバイト配列であることを示します。 –

+0

私はpython3です。 –

+0

試しましたか? –

答えて

4

jsonがロードできるように、バイト列をデコードする必要があります。 json.loadsためのコードを見てみると、それは、この例外のチェックがあります

if not isinstance(s, str): 
     raise TypeError('the JSON object must be str, not {!r}'.format(
          s.__class__.__name__)) 

あなたが通訳に行くとテストを行う場合は、バイト文字列を送信するときに例外が期待されて表示されます。

>>> a = b'abc' 
>>> type(a) 
<class 'bytes'> 
>>> b = b'abc'.decode('utf-8') 
>>> type(b) 
<class 'str'> 

ので、ajson.loadを呼び出そう:

>>> json.loads(a) 
Traceback (most recent call last): 
    File "<stdin>", line 1, in <module> 
    File "/Library/Frameworks/Python.framework/Versions/3.5/lib/python3.5/json/__init__.py", line 312, in loads 
    s.__class__.__name__)) 
TypeError: the JSON object must be str, not 'bytes' 
>>> 

ので、この場合はあなたのソリューションはでデコードすることです

import json 

data = b'{"nonce":"820346305172674795","hash":"CF9558F1AC5AA3F4F3D598BAD50D8E0FD15E536A98095C01AD1BA962BDF342D0E37CF6ED595758B3217CA1986238B10EB729D5C5EBCE1523B41328365E936DBE","encryptedMessage":"ABF47CA76B72388B3CA8F4BF95D199D02835C5AED546CC6A6A35663C312093DB05E3765A00211242770136D7F2391A2A69CCA28B4D9695","signature":"09036C211B6386AD0B1D7EDA14AE4C4C77721916C9AF48E7141049E2773098665776AA4B7CC6E12B4B5BD1FBB3B590F41C6254313BAEBA9293D87769F1A4200468747470733A2F2F3139322E3136382E312E38343A353030302F746F67676C655F646F6F722431"}' 

decoded_data = data.decode('utf-8') 
json_data = json.loads(decoded_data) 

出力:

u'nonce': u'820346305172674795', u'hash': u'CF9558F1AC5AA3F4F3D598BAD50D8E0FD15E536A98095C01AD1BA962BDF342D0E37CF6ED595758B3217CA1986238B10EB729D5C5EBCE1523B41328365E936DBE', u'encryptedMessage': u'ABF47CA76B72388B3CA8F4BF95D199D02835C5AED546CC6A6A35663C312093DB05E3765A00211242770136D7F2391A2A69CCA28B4D9695', u'signature': u'09036C211B6386AD0B1D7EDA14AE4C4C77721916C9AF48E7141049E2773098665776AA4B7CC6E12B4B5BD1FBB3B590F41C6254313BAEBA9293D87769F1A4200468747470733A2F2F3139322E3136382E312E38343A353030302F746F67676C655F646F6F722431'} 
+0

python3にはdata.decodeがありません。私はcodecs.decode(文字列、 "utf-8")を使っていて、それをjson.loadsに渡しています。いいえのサイコロ –

+4

私が答えた答えはすべてPython 3.5で行われました。あなたが何を言っているのか分かりません。 – idjaw

+1

私はこれを受け入れています。私は考えていない、それは間違いなく前に動作しませんでした。私はPythonにはまったく慣れていません。ありがとう、それは今働く。 –

関連する問題