如何将MongoDB find()查询转换为PyMongo字典?

时间:2014-06-06 19:52:53

标签: python mongodb pymongo

我在PyMongo集合中成功使用find()连接和查询(或更确切地说是MongoDB)文档。

然而,我遇到了一个问题。使用MongoDB接口,我可以执行命令:

db.mycollection.find({ $and: [{filename: {$regex: '\\.part_of_my_name'} }, {bases: {$gt: 10000 } } ] } )

它很棒。但是,当我尝试在PyMongo中执行此命令时,我发现PyMongo的{​​{1}}声明只需要一个Python find()对象。如果提供了字符串,它实际上会引发异常。

所以我的问题是:如何将上述JSON(?)字符串转换为字典?

我尝试手动构建它,但它过于复杂,我想知道是否有一种简单的方法可以从字符串转到字典。

1 个答案:

答案 0 :(得分:3)

要从字符串转到字典,您可以使用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}}]}