为什么mongodb motor无法正确解析数据?

时间:2016-03-21 18:06:06

标签: mongodb tornado tornado-motor

我有一个巨大的龙卷风应用程序,以阻止的方式编写。我试图将我的db调用转换为运行异步。我有很多问题。

我将mongo调用保存在名为lib的顶级文件夹中,并在app文件夹中保留所有视图。

我得到的错误

Traceback (most recent call last):
  File "/Users/marcsantiago/staging_env/lib/python2.7/site-packages/tornado/web.py", line 1445, in _execute
    result = yield result
  File "/Users/marcsantiago/staging_env/lib/python2.7/site-packages/tornado/gen.py", line 1008, in run
    value = future.result()
  File "/Users/marcsantiago/staging_env/lib/python2.7/site-packages/tornado/concurrent.py", line 232, in result
    raise_exc_info(self._exc_info)
  File "/Users/marcsantiago/staging_env/lib/python2.7/site-packages/tornado/gen.py", line 1017, in run
    yielded = self.gen.send(value)
  File "/Users/marcsantiago/pubgears/app/admin.py", line 179, in get
    notes, start_date, stats, last_updated = self.db_data()
  File "/Users/marcsantiago/pubgears/app/admin.py", line 76, in db_data
    while (yield chain_slugs_updated.fetch_next):
AttributeError: 'NoneType' object has no attribute 'fetch_next'

所以在lib文件夹中我有这个方法。

def get_chains_updated(date):
  slugs = []
  # Chain class can't do aggregate could create a class instance if i want
  cursor = db.chain.aggregate([
    {'$match':{'last_update':{'$gt':date}}}, 
    {'$group':{'_id':{'site':'$site'}, 'total':{'$sum':'$count'}}}
  ])

  while (yield cursor.fetch_next):
    res = yield cursor.next_object()
    slugs.append(res['_id']['site'])

  yield slugs

稍后我将此方法称为我的观点之一

chain_slugs_updated = yield chaindb.get_chains_updated(yesterday)
slugs = []
#for site in chain_slugs_updated:
while (yield chain_slugs_updated.fetch_next):
  site = chain_slugs_updated.next_object()
  slugs.append('<a href="/admin/sites/settings?slug=%s">%s</a>' % (site, site))
notes.append('<strong>%s</strong> chains have been updated in the past 24 hours (%s).' % (chain_slugs_updated.count(), ', '.join(slugs)))

这就是我使用pymongo时的用法 LIB

def get_chains_updated(date):
  slugs = []
  # Chain class can't do aggregate could create a class instance if i want
  results = db.chain.aggregate([
    {'$match':{'last_update':{'$gt':date}}}, 
    {'$group':{'_id':{'site':'$site'}, 'total':{'$sum':'$count'}}}
  ])
  for res in results:
    slugs.append(res['_id']['site'])
  return slugs

视图

chain_slugs_updated = chaindb.get_chains_updated(yesterday)
    slugs = []
    for site in chain_slugs_updated:
      slugs.append('<a href="/admin/sites/settings?slug=%s">%s</a>' % (site, site))
    notes.append('<strong>%s</strong> chains have been updated in the past 24 hours (%s).' % (len(chain_slugs_updated), ', '.join(slugs)))

我需要翻译大量代码才能使这个异步正常工作,我非常感谢任何帮助。感谢。

1 个答案:

答案 0 :(得分:1)

要从get_chains_updated返回对象列表,您必须return slugs列表(Python 3)或raise gen.Return(slugs)(所有Python版本)。有关详细信息,请参阅Refactoring Tornado Coroutines