我尝试使用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
解决方法:
根据pymongo使用字典的方式,您可能可以使用OrderedDict(来自内置collections模块).这仅在python 2.7中可用,但是有从python 2.4开始的反向移植.
在这种情况下,您可以执行以下操作:
from collections import OrderedDict
config = OrderedDict((
("cloneCollection", "db_name.collection_name"),
("from", "localhost:27017"),
))
db.command(config)