У меня есть следующий совокупный запрос монго
db.configurations.aggregate([{$group:{_id:{model:"$model", vendor :"$vendor",access_level : "$access_level",config_data_type :"$config_data_type"}, dups:{$push:"$_id"}, count: {$sum: 1}}},
{$match:{count: {$gt: 1}}}
]).forEach(function(doc){
doc.dups.shift();
db.configurations.remove({_id : {$in: doc.dups}});
});
Для pymongo я написал эквивалент этого:
pipeline = [{"$group":{"_id":{"model":"$model", "vendor" :"$vendor","access_level" : "$access_level","config_data_type" :"$config_data_type"}, "dups":{"$push":"$_id"}, "count": {"$sum": 1}}},{"$match":{"count": {"$gt": 1}}}]
dest_col.aggregate(pipeline).forEach(bson.Code( '''
function(doc){
doc.dups.shift();
dest_col.remove({"_id ": {"$in": doc.dups}});
}'''));
Это приводит к следующей ошибке:
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
AttributeError: 'CommandCursor' object has no attribute 'forEach'
Пожалуйста, исправьте, если я сделал какую-либо синтаксическую ошибку. или дайте мне знать, если какой-либо другой формат мне нужно следовать, чтобы заставить его работать