首页 > 解决方案 > 检测使用 async def 创建的任何函数

问题描述

我对 Python 3.6+ 中的以下行为感到困惑:

>>> def f1(): pass
>>> def f2(): yield
>>> async def f3(): pass
>>> async def f4(): yield
>>> inspect.isfunction(f1)
True
>>> inspect.isfunction(f2)
True
>>> inspect.iscoroutinefunction(f3)
True
>>> inspect.iscoroutinefunction(f4)
False

同步函数和生成器函数都被检查视为“函数”,但异步生成器函数不被视为“协程函数”。这似乎与文档相反

inspect.iscoroutinefunction(object)

如果对象是协程函数(使用 async def 语法定义的函数),则返回 true。

有没有比同时检查和更好的方法来检测一个函数是否是用 定义的async,包括生成器函数?iscoroutinefunctionisasyncgenfunction

这可能是因为异步生成器只出现在 3.6 中,但仍然令人费解。

标签: pythonpython-3.6python-asynciopython-3.7coroutine

解决方案


异步生成器本身不是协程,不能await编辑:

>>> loop.run_until_complete(f4())
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
  File "/home/haugh/.pyenv/versions/3.6.6/lib/python3.6/asyncio/base_events.py", line 447, in run_until_complete
    future = tasks.ensure_future(future, loop=self)
  File "/home/haugh/.pyenv/versions/3.6.6/lib/python3.6/asyncio/tasks.py", line 526, in ensure_future
    raise TypeError('An asyncio.Future, a coroutine or an awaitable is '
TypeError: An asyncio.Future, a coroutine or an awaitable is required

我认为您已经确定了检查是否async用于定义函数的最佳方法:

def async_used(func):
    return inspect.iscoroutinefunction(func) or inspect.isasyncgenfunction(func)

推荐阅读