從字符串到一本字典去,你可以使用json.loads
:
>>> import json
>>> json.loads('{"key":"value"}')
{'key': 'value'}
但是,你不能總是複製和粘貼MongoDB的命令,並期望它是有效的JSON。例如:
>>> json.loads('{$and: [{filename: {$regex: "\\.part_of_my_name"} }, {bases: {$gt: 10000 }}]}')
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/json/__init__.py", line 338, in loads
return _default_decoder.decode(s)
File "/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/json/decoder.py", line 365, in decode
obj, end = self.raw_decode(s, idx=_w(s, 0).end())
File "/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/json/decoder.py", line 381, in raw_decode
obj, end = self.scan_once(s, idx)
ValueError: Expecting property name: line 1 column 2 (char 1)
爲了使它在Python中工作,所有的鍵都需要明確引用。所以$and
需要變成"$and"
。此外,你將不得不使用額外的轉義反斜槓(有點醜,我知道)。
在你的榜樣查詢應該是這樣的:
jsonString = '{"$and":[{"filename":{"$regex":"\\\\.part_of_my_name"}},{"bases":{"$gt":10000}}]}'
然後,您可以用就可以了json.loads。然而,在這一點上它是一個有效的Python字典,所以你可以使用這個:
jsonDict = {"$and":[{"filename":{"$regex":"\\.part_of_my_name"}},{"bases":{"$gt":10000}}]}