python协程获取返回值(四种方式)

一、通过ensure_future获取,本质是future对象中的result方法

import asyncio
from functools import partial

async def talk(name):
	print("talk running!!!")
	await asyncio.sleep(1)
	return f"{name} talk"

async def sleep(work):
	print("sleep running!!!")
	await asyncio.sleep(0.1)
	return f"{work} sleep"

if __name__ == "__main__":
	# 通过ensure_future获取,本质是future对象中的result方法
	loop = asyncio.get_event_loop()
	get_future1 = asyncio.ensure_future(talk("Dog"))
	get_future2 = asyncio.ensure_future(sleep("Cat"))
	loop.run_until_complete(get_future1)
	loop.run_until_complete(get_future2)
	print(get_future1.result())
	print(get_future2.result())

打印结果:

talk running!!!
sleep running!!!
Dog talk
Cat sleep

二、使用loop自带的create_task,获取返回值

import asyncio
from functools import partial

async def talk(name):
	print("talk running!!!")
	await asyncio.sleep(1)
	return f"{name} talk"

async def sleep(work):
	print("sleep running!!!")
	await asyncio.sleep(0.1)
	return f"{work} sleep"

if __name__ == "__main__":
	# 使用loop自带的create_task,获取返回值
	loop = asyncio.get_event_loop()
	task1 = loop.create_task(talk("Dog"))
	task2 = loop.create_task(sleep("Cat"))
	loop.run_until_complete(task1)
	loop.run_until_complete(task2)
	print(task1.result())
	print(task2.result())

打印结果:

talk running!!!
sleep running!!!
Dog talk
Cat sleep

三、使用callback,一旦await地方的内容运行完,就会运行callback

import asyncio
from functools import partial

async def tack(name):
	print("talk running!!!")
	await asyncio.sleep(1)
	return f"{name} talk"

async def sleep(work):
	print("sleep running!!!")
	await asyncio.sleep(0.1)
	return f"{work} sleep"

def callback(value):
	print(f"主动抛出接收返回值:{value}")

if __name__ == "__main__":
	# 使用callback,一旦await地方的内容运行完,就会运行callback
	loop = asyncio.get_event_loop()
	task1 = loop.create_task(tack("Dog"))
	task2 = loop.create_task(sleep("Cat"))
	task1.add_done_callback(callback)
	task2.add_done_callback(callback)
	loop.run_until_complete(task1)
	loop.run_until_complete(task2)
	print(task1.result())
	print(task2.result())
	

打印结果:

talk running!!!
sleep running!!!
主动抛出接收返回值:<Task finished name='Task-2' coro=<sleep() done, defined at D:/python_files/py2022_02/Case01/ceshi.py:24> result='Cat sleep'>
主动抛出接收返回值:<Task finished name='Task-1' coro=<tack() done, defined at D:/python_files/py2022_02/Case01/ceshi.py:19> result='Dog talk'>
Dog talk
Cat sleep

四、使用partial这个模块向callback函数中传入值

import asyncio
from functools import partial

async def talk(name):
	print("talk running !!!")
	await asyncio.sleep(1)
	return f"{name} talk"

async def sleep(work):
	print("sleep running!!!")
	await asyncio.sleep(0.1)
	return f"{work} sleep"
	
def callback(value):
    print(f"主动抛出接收返回值:{value}")

if __name__ == "__main__":
	# 使用partial这个模块向callback函数中传入值
	loop = asyncio.get_event_loop()
	task1 = loop.create_task(talk("Dog"))
	task2 = loop.create_task(sleep("Cat"))
	task1.add_done_callback(partial(callback))
	task2.add_done_callback(partial(callback))
	loop.run_until_complete(task1)
	loop.run_until_complete(task2)
	print(task1.result())
	print(task2.result())

打印结果:

talk running !!!
sleep running!!!
主动抛出接收返回值:<Task finished name='Task-2' coro=<sleep() done, defined at D:/python_files/py2022_02/Case01/ceshi.py:25> result='Cat sleep'>
主动抛出接收返回值:<Task finished name='Task-1' coro=<talk() done, defined at D:/python_files/py2022_02/Case01/ceshi.py:19> result='Dog talk'>
Dog talk
Cat sleep
  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 你可以使用 asyncio 库中的 async 和 await 关键字来运行协程。 例如: ```python import asyncio async def my_coroutine(param): # 协程函数体 result = do_something(param) return result async def main(): # 在主函数中运行协程 result = await my_coroutine(42) print(result) # 运行主函数 asyncio.run(main()) ``` 你也可以使用 asyncio.gather() 函数来同时运行多个协程,并获取它们的返回值: ```python import asyncio async def my_coroutine_1(param): # 协程函数体 result = do_something(param) return result async def my_coroutine_2(param): # 协程函数体 result = do_something_else(param) return result async def main(): # 并发运行协程 results = await asyncio.gather( my_coroutine_1(42), my_coroutine_2(43), ) print(results) # 运行主函数 asyncio.run(main()) ``` 在上面的示例中, my_coroutine_1 和 my_coroutine_2 会同时运行,并在它们都完成后,将它们的返回值放在一个列表中返回。 ### 回答2: 在Python中,我们可以使用协程(Coroutine)来实现并发运行并获取返回值协程是一种轻量级的线程,可以在运行过程中暂停和恢复,可以在一个线程中执行多个任务,实现并发效果。 使用Python的asyncio库可以轻松实现协程,并发运行协程方式有多种,以下是其中一种常见的方式,使用asyncio.gather()函数来同时运行多个协程,并获取返回值。 首先,我们需要定义多个协程函数,这些函数可以是普通的函数加上@asyncio.coroutine装饰器,也可以是async def定义的异步函数。这些协程函数可以是耗时的任务,如网络请求、IO读写等。 然后,我们使用asyncio.gather()函数来并发运行这些协程函数,该函数接受一个或多个协程对象作为参数,并返回一个包含所有协程返回值的列表。 最后,我们可以使用事件循环(Event Loop)来运行整个程序,并获取协程函数的返回值。事件循环是协程并发运行的引擎,负责调度和执行协程任务。 以下是一个示例代码: import asyncio # 定义协程函数 async def coro1(): return "Hello" async def coro2(): return "World" # 创建事件循环 loop = asyncio.get_event_loop() # 并发运行多个协程 tasks = [coro1(), coro2()] results = loop.run_until_complete(asyncio.gather(*tasks)) # 打印结果 print(results) 在上述示例代码中,我们定义了两个协程函数coro1()和coro2(),分别返回"Hello"和"World"。然后,我们在事件循环中使用asyncio.gather()函数并发运行这两个协程函数,并将返回值存储在results列表中。最后,我们打印出结果。 通过这种方式,我们可以方便地实现Python中的协程并发运行,并获取返回值。这种方式非常适合处理并发任务,提高程序的效率。 ### 回答3: Python中的协程是一种轻量级的并发编程方式,可以在单线程中同时运行多个任务,提高程序的执行效率。在Python中有许多支持协程的库,如asyncio和gevent。下面是使用asyncio库实现并发运行协程获取返回值的步骤: 1. 首先,导入asyncio库和相应的模块。创建一个asyncio的事件循环对象。 2. 接下来,定义一个协程函数,使用async关键字声明。在协程函数中编写你的业务逻辑代码,并使用await关键字等待异步任务完成。 3. 在主函数中,使用asyncio的gather()函数来运行多个协程任务。将协程任务作为gather()函数的参数传入,以创建一个任务列表。 4. 调用事件循环对象的run_until_complete()方法,将任务列表作为参数传入,执行任务。 5. 在run_until_complete()方法返回后,可以通过调用协程对象的result()方法来获取协程任务的返回值。result()方法是一个属性,如果任务成功完成,它将返回任务的结果。 下面是一个简单的示例代码: ```python import asyncio async def task(name): # 模拟耗时任务 await asyncio.sleep(1) return f"Hello, {name}" async def main(): tasks = [task("Alice"), task("Bob") ] results = await asyncio.gather(*tasks) for result in results: print(result) if __name__ == "__main__": loop = asyncio.get_event_loop() loop.run_until_complete(main()) ``` 在上面的示例中,定义了一个名为task的协程函数,它会模拟一个耗时任务并返回一个字符串。main()函数中创建了两个任务,并使用asyncio.gather()将它们组合成一个任务列表。最后通过循环打印出每个任务的返回值。 运行以上代码,你将看到类似如下输出: ``` Hello, Alice Hello, Bob ``` 这是两个协程任务返回的结果。这里使用asyncio库实现协程的并发运行并获取返回值,不同的库和框架可能具有类似或不同的方式
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值