Je pense que ce que vous vouliez est ceci :
print db.dvds.aggregate([
{"$unwind": "$episodes"}, # One document per episode
{"$match": {"episodes.title": "Episode 1"} }, # Selects (filters)
{"$group": {"_id": "$_id", # Put documents together again
"episodes": {"$push": "$episodes"},
"title": {"$first": "$title"} # Just take any title
}
},
])["result"]
Le résultat (en plus des espaces blancs) est :
[ { u'episodes': [ { u'title': u'Episode 1',
u'desc': u'...'
}
],
u'_id': ObjectId('51542645a0c6dc4da77a65b6'),
u'title': u'The Hitchhikers Guide to the Galaxy'
}
]
Si vous voulez vous débarrasser du u"_id"
, ajoutez au pipeline :
{"$project": {"_id": 0,
"episodes": "$episodes",
"title": "$title"}
}