Вопрос-Ответ

Convert a String representation of a Dictionary to a dictionary

Преобразование строкового представления словаря в dictionary

Как я могу преобразовать str представление словаря, например следующую строку, в dict?

s = "{'muffin' : 'lolz', 'foo' : 'kitty'}"

Я предпочитаю не использовать eval. Что еще я могу использовать?

Переведено автоматически
Ответ 1

Вы можете использовать встроеннуюast.literal_eval:

>>> import ast
>>> ast.literal_eval("{'muffin' : 'lolz', 'foo' : 'kitty'}")
{'muffin': 'lolz', 'foo': 'kitty'}

Это безопаснее, чем использование eval. Как говорится в его собственных документах:

>>> справка (ast.literal_eval)
Справка по функции literal_eval в модуле ast:

literal_eval(node_or_string)
Безопасное вычисление узла выражения или строки, содержащей Python
выражение. Предоставленная строка или узел могут состоять только из следующего
Литеральные структуры Python: строки, числа, кортежи, списки, dicts, логические значения,
и None.

Например:

>>> eval("shutil.rmtree('mongo')")
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "<string>", line 1, in <module>
File "/opt/Python-2.6.1/lib/python2.6/shutil.py", line 208, in rmtree
onerror(os.listdir, path, sys.exc_info())
File "/opt/Python-2.6.1/lib/python2.6/shutil.py", line 206, in rmtree
names = os.listdir(path)
OSError: [Errno 2] No such file or directory: 'mongo'
>>> ast.literal_eval("shutil.rmtree('mongo')")
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "/opt/Python-2.6.1/lib/python2.6/ast.py", line 68, in literal_eval
return _convert(node_or_string)
File "/opt/Python-2.6.1/lib/python2.6/ast.py", line 67, in _convert
raise ValueError('malformed string')
ValueError: malformed string
Ответ 2

https://docs.python.org/library/json.html

JSON может решить эту проблему, хотя его декодер заключает ключи и значения в двойные кавычки. Если вы не возражаете против взлома замены...

import json
s = "{'muffin' : 'lolz', 'foo' : 'kitty'}"
json_acceptable_string = s.replace("'", "\"")
d = json.loads(json_acceptable_string)
# d = {u'muffin': u'lolz', u'foo': u'kitty'}

ОБРАТИТЕ внимание, что если у вас есть одинарные кавычки как часть ваших ключей или значений, это приведет к сбою из-за неправильной замены символов. Это решение рекомендуется только в том случае, если вы испытываете сильное отвращение к решению eval.

Подробнее об одинарной кавычке json: jQuery.parseJSON выдает ошибку “Invalid JSON” из-за экранированной одинарной кавычки в JSON

Ответ 3

использование json.loads:

>>> import json
>>> h = '{"foo":"bar", "foo2":"bar2"}'
>>> d = json.loads(h)
>>> d
{u'foo': u'bar', u'foo2': u'bar2'}
>>> type(d)
<type 'dict'>
Ответ 4

К примеру OP:

s = "{'muffin' : 'lolz', 'foo' : 'kitty'}"

Мы можем использовать Yaml для работы с такого рода нестандартным json в string:

>>> import yaml
>>> s = "{'muffin' : 'lolz', 'foo' : 'kitty'}"
>>> s
"{'muffin' : 'lolz', 'foo' : 'kitty'}"
>>> yaml.load(s)
{'muffin': 'lolz', 'foo': 'kitty'}
python string dictionary