首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何在ResultProxy上多次迭代?

如何在ResultProxy上多次迭代?
EN

Stack Overflow用户
提问于 2016-10-05 17:53:17
回答 1查看 2.8K关注 0票数 4

假设我执行以下查询:

代码语言:javascript
复制
results = db.engine.execute(sql_query)

其中,它按预期返回行:

代码语言:javascript
复制
>>> for record in results:
...     print(record['path'])
... 
Top.Collections.Pictures.Astronomy.Stars
Top.Collections.Pictures.Astronomy.Galaxies
Top.Collections.Pictures.Astronomy.Astronauts

当我尝试第二次或第三次迭代它时,对象是空的:

代码语言:javascript
复制
>>> for record in results:
...     print(record['path'])
...
>>> 

如何保存和重用ResultProxy以多次迭代它?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-10-05 17:55:15

您可能有一个迭代器对象被返回,所以一旦它在迭代之后耗尽,就不能再遍历它了。假设您的结果不是非常大,您可以这样做:

代码语言:javascript
复制
results = db.engine.execute(sql_query) 
results = list(results)

这将迭代器对象转换为一个列表,您可以尽可能多地遍历它。

票数 7
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/39880685

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档