在pymongo的runco​​mmand中使用“from”作为kwarg键

时间:2014-01-31 08:21:20

标签: python mongodb clone pymongo mongo-collection

我正在尝试使用pymongo从远程mongo实例克隆集合,从documentation克隆集合需要cloneCollection命令,

{ cloneCollection: "<collection>", from: "<hostname>", query: { <query> } }

run this command in pymongo我需要将命令的其他参数指定为像这样的kwargs:

db.command("cloneCollection","db_name.collection_name", from = "localhost:27017")

但是因为from是python中的保留关键字,所以我不能将它用作关键字。 另一种方法是将命令作为python dict传递,如下所示:

db.command({"cloneCollection":"db_name.collection_name", "from":"localhost:27017"})

但是在这种情况下,订单不会保留,我收到此错误

pymongo.errors.OperationFailure: command {'from': 'localhost:27017', 'cloneCollection': 'db_name.collection_name'} failed: no such cmd: from

2 个答案:

答案 0 :(得分:2)

认为我可以使用bson.son.SON来创建一个SON对象(维护键的顺序的dict的子类),当我们将参数或python dict传递给pymongo命令时,pymongo也在内部执行此操作,

from bson.son import SON
db.command(SON([("cloneCollection","db_name.collection_name"), ("from","localhost:27017")]))

答案 1 :(得分:2)

根据pymongo如何使用字典,您可以使用OrderedDict(来自内置集合模块)。这只能从python 2.7中获得,但是从python 2.4开始可以使用backports。

在这种情况下,您可以执行以下操作:

from collections import OrderedDict
config = OrderedDict((
    ("cloneCollection", "db_name.collection_name"),
    ("from", "localhost:27017"),
))
db.command(config)