我正在尝试使用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
答案 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)