将字符串形式的字典转换为字典
我想知道怎么把一个字典的字符串表示,比如下面这个字符串,转换成一个真正的字典。
s = "{'muffin' : 'lolz', 'foo' : 'kitty'}"
我不太想用 eval
,那还有什么其他的方法可以用呢?
13 个回答
237
使用 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'>
412
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因为JSON中的转义单引号而抛出“无效的JSON”错误
1687
你可以使用内置的 ast.literal_eval
:
>>> import ast
>>> ast.literal_eval("{'muffin' : 'lolz', 'foo' : 'kitty'}")
{'muffin': 'lolz', 'foo': 'kitty'}
这个方法比使用 eval
更安全。正如它自己的文档所说:
>>> help(ast.literal_eval) Help on function literal_eval in module ast: literal_eval(node_or_string) Safely evaluate an expression node or a string containing a Python expression. The string or node provided may only consist of the following Python literal structures: strings, numbers, tuples, lists, dicts, booleans, and 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