1

如何使用 MongoEngine/Flask-MongoEngine 在 Flask 中一次向文档添加多个条目?

我试图遍历包含我的条目的字典。我稍微简化了示例,但最初数据是我的 Wordpress 吐出的 RSS 文件,我通过feedparser.

但问题显然是我无法在保存到数据库之前动态生成保存我的条目的变量。

这是我到目前为止所尝试的。

如何将条目批量添加到我的 MongoDB 数据库中?

# model
class Entry(db.Document):
    created_at = db.DateTimeField(
        default=datetime.datetime.now, required=True),
    title = db.StringField(max_length=255, required=True)
    link = db.StringField(required=True)

# dictionary with entries
e = {'entries': [{'title': u'title1',
                  'link': u'http://www.me.com'
                  },
    {'title': u'title2',
     'link': u'http://www.me.com/link/'
     }
]
}

# multiple entries via views
i = 0
while i<len(e['entries']):
      post[i] = Entry(title=e['entries'][i]['title'], link=e['entries'][i]['title'])
      post[i].save();
      i += 1

编辑1:

我想过一起跳过变量并将字典翻译成mongoengine可以理解的形式。

因为当我手动创建列表时,我可以将它们批量输入到 MongoDB 中:

newList = [RSSPost(title="test1", link="http://www.google.de"),
            RSSPost(title="test2", link="http://www.test2.com")]

RSSPost.objects.insert(newList)

这可行,但我无法将其完全转化为我的问题。

我试过了

f = []

for x in e['entries']:
    f.append("insert " + x['link'] + " and " + x['title'])

但正如你所见,我无法重新创建我需要的列表。

如何正确执行?

4

2 回答 2

4
# dictionary with entries
e = {'entries': [{'title': u'title1',
                  'link': u'http://www.me.com'
                  },
    {'title': u'title2',
     'link': u'http://www.me.com/link/'
     }
]
}

您的数据/案例与您发布的示例有何不同?只要我没有遗漏任何东西,您应该能够实例化 Entry对象,例如:

entries = []
for entry in e['entries']:
    new_entry = Entry(title=entry['title'], link=entry['link'])
    entries.append(new_entry)

Entry.objects.insert(entries)
于 2014-04-25T14:28:50.207 回答
2

快速简便的方法:

for i in e['entries']:
    new_e = Entry(**i)
    new_e.save()
于 2014-04-26T00:35:36.317 回答