2014-06-06 183 views
0

我正在成功使用PyMongo連接和查詢(或更確切地說find())文件在我的MongoDB集合中。如何將MongoDB find()查詢轉換爲PyMongo字典?

但是,我遇到了一個問題。使用MongoDB接口,我可以執行命令:

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

它很好用。但是,當我嘗試在PyMongo中執行此命令時,我看到find()PyMongo聲明僅需要Python dict對象。如果提供字符串,它實際上會引發異常。

所以我的問題是:如何將上面的JSON(?)字符串轉換爲字典?

我試着手動構建它,但它太複雜了,我想知道是否有一個簡單的方法去從字符串到字典。

回答

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