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

0 投票
1 回答
2631 浏览
提问于 2025-04-18 08:54

我正在成功使用 PyMongo 来连接和查询我的 MongoDB 数据库中的文档。

不过,我遇到了一个问题。通过 MongoDB 的界面,我可以执行以下命令:

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

这个命令运行得很好。但是,当我尝试在 PyMongo 中执行这个命令时,我发现 find() 的用法要求必须传入一个 Python 的 dict 对象。如果我传入一个字符串,它会报错。

所以我想问的是:我该如何把上面的 JSON(?) 字符串转换成字典呢?

我尝试手动构建这个字典,但感觉太复杂了。我在想有没有简单的方法可以把字符串转换成字典。

1 个回答

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

撰写回答