根据 Mongoengine API 指南(http://mongoengine-odm.readthedocs.org/en/latest/apireference.html):
class mongoengine.queryset.QuerySet(document, collection)
是“从查询返回的一组结果。包装一个 MongoDB 游标,提供 Document 对象作为结果。 ”
当我type()
在解释器中检查 QuerySet 对象时,它说 QuerySet 对象是 a <class 'mongoengine.queryset.QuerySet'>
,与 API 指南一致。
我很困惑,因为为了实际访问Document
QuerySet 实例中的单个 Mongoengine 对象,我必须使用索引方法,如 [0](对于第一个Document
对象)或 [2](对于第三个Document
对象)见这个 SO question关于切片 QuerySet。有趣的是,您还可以调用len()
QuerySet 实例。
即使 QuerySet 是一个类对象,为什么它的行为看起来像一个列表对象?据我所知,它没有继承自UserList
并且没有data
属性。任何帮助将不胜感激。
谢谢。
编辑:
感谢您的建议@isbadawi。这很有帮助。QuerySet 类对象确实包含该__getitem__
方法,正如您的链接所暗示的那样,它“大致相当于”索引(例如x.__getitem__(i)
,大致相当于x[i]
)。因此,如果 QuerySet 通过 模拟列表类__getitem__
,那么实际Document
对象存储在类中的什么位置?在属性中?这是dir(QuerySet)
我的解释器的输出:
> ['_QuerySet__already_indexed', '_QuerySet__dereference', '__call__', '__class__', '__delattr__', '__dict__', '__doc__', '__format__', '__getattribute__', '__getitem__', '__hash__', '__init__', '__iter__', '__len__', '__module__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__sizeof__', '__str__', '__subclasshook__', '__weakref__', '_as_pymongo', '_as_pymongo_coerce', '_build_index_spec', '_class_check', '_collection', '_collection_obj', '_cursor', '_cursor_args', '_cursor_obj', '_dereference', '_document', '_ensure_indexes', '_fields_to_dbfields', '_get_as_pymongo', '_get_scalar', '_hint', '_initial_query', '_item_frequencies_exec_js', '_item_frequencies_map_reduce', '_iter', '_limit', '_loaded_fields', '_lookup_field', '_mongo_query', '_ordering', '_query', '_query_obj', '_reset_already_indexed', '_scalar', '_skip', '_slave_okay', '_snapshot', '_sub_js_fields', '_timeout', '_transform_query', '_transform_update', '_translate_field_name', '_where_clause', 'all', 'all_fields', 'as_pymongo', 'average', 'clone', 'count', 'create', 'delete', 'distinct', 'ensure_index', 'exclude', 'exec_js', 'explain', 'fields', 'filter', 'first', 'get', 'get_or_create', 'hint', 'in_bulk', 'insert', 'item_frequencies', 'limit', 'map_reduce', 'next', 'only', 'order_by', 'rewind', 'scalar', 'select_related', 'skip', 'slave_okay', 'snapshot', 'sum', 'timeout', 'update', 'update_one', 'values_list', 'where', 'with_id']