- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我是 Python 和函数式编程的新手。我使用的是 2.7.6 版本
我正在使用 Tornado 框架来发出异步网络请求。根据我对函数式编程的了解,我希望我的数据通过使用生成器流过我的代码。我已经使用生成器完成了我需要的大部分工作,并在数据流通过我的函数调用时转换数据。
在流的最后,我想对一些数据发出 REST 请求。在我将数据提交给 Tornado 之前,我有一个 for 循环,以启动拉取,然后发送 http 请求。 Tornado 提供的 http 对象带有一个回调函数作为一个选项,并且总是返回一个 Future——这实际上是一个 Tornado Future 对象,而不是官方的 Python Future。
我的问题是,由于我现在使用生成器通过我的代码提取数据,所以我不想再使用回调函数。我这样做的原因是,在我从回调中取回数据后,我的数据现在正在通过我的代码推送,我无法再使用生成器。
我的目标是创建一个如下所示的界面:
urls = (...generated urls...)
responses = fetch(urls)
responses 是完整 url 的生成器。
我尝试做的事情——在很多事情中——是将回调的结果转换成一个生成器。我正在考虑这样的事情,尽管我还远未针对我将很快解释的其他问题实现它。但是,我希望我的 fetch 函数看起来像这样:
def fetch(urls):
def url_generator():
while True:
val = yield
yield val
@curry
def handler(gen, response):
gen.send(response)
gen = url_generator()
for u in urls:
http.fetch(u, callback=handler(gen))
return gen
我简化了代码和语法以专注于问题,但我认为这会很好地工作。我的策略是定义一个协程/生成器,然后我会在收到响应时将其发送给它。
我遇到最多麻烦的是协程/生成器。即使我以上述方式定义一个生成器并执行以下操作,我也会得到一个无限循环——这是我的主要问题之一。
def gen():
while True:
val = yield
print 'val', val
yield val
print 'after', val
break
g = gen()
g.send(None)
g.send(10)
for e in g:
print e
如预期的那样在协程中打印 val 10 after 10
和 break,但是 for-loop 永远不会得到 10 的值。当 break 出现时它不打印任何东西。如果我删除 break,就会进入无限循环:
val None
None
after None
None
val None
None
after None
None
...
如果我删除 for 循环,那么协程将只打印 val 10
,因为它等待第二次 yield。我期待这个。但是,使用它不会产生任何结果。
类似地,如果我删除 for 循环并将其替换为 print next(g)
,则会出现 StopIteration 错误,我认为这意味着我在没有更多内容的生成器上调用了 next值(value)观。
任何人,当我深入研究 Python 时,我完全不知所措。我认为这在 Python 中很常见,以至于有人知道一个很好的方法。我搜索了“将回调转换为生成器”等,但运气不佳。
另一方面,我可能会从 http 请求中产生每个 future ,但我没有太多运气“等待” future 完成的 yield 。我读了很多关于“yield from”的文章,但它似乎是特定于 Python 3 的,而 Tornado 似乎还不适用于 Python 3。
感谢观看,也感谢您提供的任何帮助。
最佳答案
Tornado 在 Python 3 上运行良好。
上面简化代码的问题是这没有按照您的预期进行:
val = yield
您希望生成器在那里暂停(阻塞您的 for 循环)直到其他函数调用 g.send(value)
,但事实并非如此。相反,代码的行为如下:
val = yield None
因此 for 循环接收 None
值的速度与处理它们的速度一样快。它接收到每个None
后,隐式调用g.next()
,这与g.send(None)
相同。因此,您的代码等同于:
def gen():
while True:
val = yield None
print 'val', val
yield val
print 'after', val
g = gen()
g.send(None)
g.send(10)
while True:
try:
e = g.send(None)
print e
except StopIteration:
break
阅读这个版本的代码,其中隐式行为是显式的,我希望它清楚为什么它只是在无限循环中生成 None
。
您需要的是一种方法,让一个函数将项目添加到队列的头部,而另一个函数阻止等待项目,并在它们准备好时将它们从队列的尾部拉出。从 Tornado 4.2 开始,我们拥有:
http://www.tornadoweb.org/en/stable/queues.html
web spider 例子很接近你想做的,我相信你可以适应它:
关于python - 从 Python 中的协程产生一个值,也就是将回调转换为生成器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31869593/
我使用以下代码和嵌套生成器迭代文本文档并使用 get_train_minibatch() 返回训练示例。我想保留( pickle )生成器,这样我就可以回到文本文档中的相同位置。但是,您不能 pick
在本教程中,您将借助示例了解 JavaScript 生成器。在 JavaScript 中,生成器提供了一种使用函数和迭代器的新方法。 使用生成器, 您可以从函数内部的任何位置停止执行函数 并从
LESS is very cool .我一直想知道是否有任何好的 html 生成器可以让我更轻松地编写表单或做其他事情。除了 html,是否有一些类似的东西? 最佳答案 已尝试 Haml ? 从它的网
前言 如果是做python或者其他语言的小伙伴,对于生成器应该不陌生。但很多php开发者或许都不知道生成器这个功能,可能是因为生成器是php 5.5.0才引入的功能,也可以是生成器作用不是很明显。
我正在尝试编写一个使用生成器语法生成日期时间列表的函数: let dateRange = let endDate = System.DateTime.Parse("6/1/2010")
我遇到了一些看起来像的代码: [func(val) for val in iterable] 有一个可迭代对象(在我的例子中是一个生成器),用户想要为其副作用调用每个值的函数(例如 func 可以只是
Delphi 有内置的东西来生成 UUID 吗? 最佳答案 program Guid; {$APPTYPE CONSOLE} uses SysUtils; var Uid: TGuid; Result
我正在深入研究 javascript 生成器,但我真的很困惑。 我使用 node@0.11.x 运行此示例: function find() { process.nextTick(functi
有人知道一些关于如何为 hibernate 创建自定义 ID 生成器的好教程吗? 最佳答案 在 Google 上粗略搜索“hibernate 自定义 id 生成器教程”发现了以下可能性。我排除了那些看
我正在关注 Python 大师 David Beazley 的幻灯片。它指出“生成器也用于并发。这是一个示例: from collections import deque def countdown(
我有一个生成事件的生成器,我想用可以从 API 获取的附加元数据来丰富它。 某些事件具有与其链接的对象 ID,而其他事件则具有对象的哈希值,但不能同时具有两者。我无法根据哈希获取对象 id,我只能执行
假设我有一个自定义类: public class CustomClass { private String name; private String data; public
我正在考虑实现一个函数来在 SQL 请求中“构建”WHERE 子句,如下所示: "SELECT * FROM table $where" 使用如下所示的循环构建 $where: $arr=array(
我正在寻找执行此操作的标准函数: def Forever(v): while True: yield v 这看起来太琐碎了,我不敢相信没有标准版本。 就此而言,有人知道指向所有标准生成器函
我知道这个网站上有几个非常相似的相关问题,但是在看了这部剧之后,我相信这个问题本身就是独一无二的。如果有人能找到并提供证据证明我的问题完全被骗了,我会自己撤回它(所以请不要否决这个!)。 我是 Jav
void __fastcall TForm1::Button1Click(TObject *Sender) { int size = MemoEnter->GetTextLen() + 1;
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我试图在我的生成器的以下两个定义之间做出决定。哪个更好?哪个“更像 python ”?无论如何,有没有办法减轻每一个的缺点? def myGenerator1(howMany): result
我有一个 Python 生成器 lexg,它在每次迭代时生成一个列表。该代码似乎在传统的 for 循环意义上工作,即 for i in lexg(2,2): print(i) 产生: [2, 0] [
我希望这不会超出 Python 生成器的能力,但我想构建一个这样,每次调用该函数时,它都会返回下一分钟直到结束时间。 因此该函数读取开始时间和结束时间,并以分钟为单位返回时间,直到涵盖其间的所有时间。
我是一名优秀的程序员,十分优秀!