-1


我尝试使用 pymongo 驱动程序用 python 框架 Flask 和 MongoDB 编写一个 webapp。
我需要获得管理员视图,以便能够在线编辑数据,

集合的结构:

db.skills.insert({ "rubric": rubric, "head": title, "body": content })

(如果值 < 0,则每个字段都可以是 $unset)

在控制器中,我通过创建 dict 列表将数据发送到视图:

def skList():
    liste, keys, value = [], [], []
# iterate over the collection to get 2 list of all keys and values.
    for row in db.skills.find():
        keys.append(row.keys())
        value.append(row.values())
# merge the 2 lists.
    zipped = zip(keys, value)
# finally create a list of dict containing each row of my db
    for x, y in zipped:
        liste.append(dict(zip(x, y)))
    return liste

结果是这样的:

liste = [ {_id:ObjectId('89878979879'), 'rubric':'Python', 'body': 'truc'}, {_id:ObjectId('876876899'), 'rubric':'chose', 'head':'blabla', 'body':'foo'} ]

在我看来,我迭代并显示正常!
我也可以编辑/删除每个字段,或删除文档。

当我开始从视图添加数据时出现我的问题:

有时,从视图中添加的下一个文档是集合中间的插入,因此顺序不固定,
从 mongo shell 追加相同的内容。

我在这里找到了解释:
https ://groups.google.com/d/msg/mongodb-user/B5jU0uyGhh8/i3LacXcXKDwJ

所以我必须处理我不希望文档由视图显示并且不知道如何执行此操作的顺序:p

有人可以提出一个解决方案,也许我应该使用不同的模式?

4

1 回答 1

0

有迭代集合 Mongo 并返回按每个文档的“索引”字段排序的 dict 列表的解决方案:

def collecList(collection):
    liste, keys, value = [], [], []
    for row in collection.find().sort("index"):
        keys.append(row.keys())
        value.append(row.values())
    zipped = zip(keys, value)
    for x, y in zipped:
         liste.append(dict(zip(x, y)))
    return liste
于 2013-11-13T19:05:12.803 回答