Convertir una representación de cadena de un diccionario en un diccionario

Resuelto UberJumper asked hace 15 años • 13 respuestas

¿Cómo puedo convertir la strrepresentación de un diccionario, como la siguiente cadena, en dict?

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

Prefiero no usarlo eval. ¿Qué más puedo usar?

UberJumper avatar Jun 13 '09 01:06 UberJumper
Aceptado

Puedes usar el incorporado ast.literal_eval:

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

Esto es más seguro que usar eval. Como dicen sus propios documentos:

>>> ayuda(ast.literal_eval)
Ayuda sobre la función literal_eval en el módulo ast:

literal_eval(nodo_o_cadena)
    Evalúe de forma segura un nodo de expresión o una cadena que contenga un Python
    expresión. La cadena o nodo proporcionado solo puede consistir en lo siguiente
    Estructuras literales de Python: cadenas, números, tuplas, listas, dictados, booleanos,
    y Ninguno.

Por ejemplo:

>>> 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
Jacob Gabrielson avatar Jun 12 '2009 18:06 Jacob Gabrielson

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

JSON puede resolver este problema, aunque su decodificador quiere comillas dobles alrededor de claves y valores. Si no te importa un truco de reemplazo...

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'}

TENGA EN CUENTA que si tiene comillas simples como parte de sus claves o valores, esto fallará debido a un reemplazo inadecuado de caracteres. Esta solución solo se recomienda si tiene una gran aversión a la solución de evaluación.

Más información sobre las comillas simples json: jQuery.parseJSON arroja el error "JSON no válido" debido a una comilla simple escapada en JSON

i0x539 avatar Oct 15 '2013 21:10 i0x539

usando 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'>
tokhi avatar Aug 15 '2014 12:08 tokhi