3

pymongo を使用して、リモートの mongo インスタンスからコレクションを複製しようとしています。ドキュメントcloneCollectionから、コレクションの複製には次のコマンドが必要です。

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

このコマンドを 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
4

2 に答える 2

2

pymongo が辞書をどのように使用するかによっては、(組み込みコレクション モジュールから) OrderedDictを使用できる場合があります。これは python 2.7 からのみ利用可能ですが、python 2.4 以降で利用可能なバックポートがあります。

この場合、次のようなことができます。

from collections import OrderedDict
config = OrderedDict((
    ("cloneCollection", "db_name.collection_name"),
    ("from", "localhost:27017"),
))
db.command(config)
于 2014-01-31T09:19:26.753 に答える
2

bson.son.SONを使用して SON オブジェクト (キーの順序を維持する dict のサブクラス) を作成できると考えた場合、pymongo は、引数または python dict を pymongo コマンドに渡すときにもこれを内部的に行います。

from bson.son import SON
db.command(SON([("cloneCollection","db_name.collection_name"), ("from","localhost:27017")]))
于 2014-01-31T08:32:26.420 に答える