次のようなバイト型オブジェクトがあります。
b"{'one': 1, 'two': 2}"
pythonコードを使用して、辞書から辞書を取得する必要があります。これを文字列に変換し、次のように辞書に変換しています。
string = dictn.decode("utf-8")
print(type(string))
>> <class 'str'>
d = dict(toks.split(":") for toks in string.split(",") if toks)
しかし、私は以下のエラーが発生しています:
------> d = dict(toks.split(":") for toks in string.split(",") if toks)
TypeError: 'bytes' object is not callable
あなたに必要なのは ast.literal_eval
。それ以上に素晴らしいものはありません。文字列でPython以外のdict構文を具体的に使用していない限り、JSONを台無しにする理由はありません。
import ast
ast.literal_eval(b"{'one': 1, 'two': 2}")
print(repr(d))
回答を参照してください こちら 。 ast.literal_eval
はeval
より安全です。
適切な辞書を取得するにはデコードも必要だと思います。
a= b"{'one': 1, 'two': 2}"
ast.literal_eval(a.decode('utf-8'))
**Output:** {'one': 1, 'two': 2}
受け入れられた答えは
a= b"{'one': 1, 'two': 2}"
ast.literal_eval(repr(a))
**output:** b"{'one': 1, 'two': 2}"
Literal_evalは私のコードの多くで適切にそれを行っていないので、私は個人的にこのためにjsonモジュールを使用することを好みます
import json
a= b"{'one': 1, 'two': 2}"
json.loads(a.decode('utf-8'))
**Output:** {'one': 1, 'two': 2}