假设我有这样的代码
async def fetch_text() -> str:
return "text "
async def show_something():
something = await fetch_text()
print(something)
没关系但是然后我想清除数据,所以我这样做
async def fetch_text() -> str:
return "text "
def fetch_clean_text(text: str) -> str:
text = await fetch_text()
return text.strip(text)
async def show_something():
something = fetch_clean_text()
print(something)
(我可以清理show_something()
中的文本,但让我们假设show_something()
可以打印很多东西,并且不知道或不应该知道清理它们的正确方法。)
这当然是SyntaxError: 'await' outside async function
。但是,如果此代码可以运行,则当await
表达式未放置在协程函数内部时,它将在一个上下文中执行。为什么不允许这种行为?
我看到这种设计的一个专业人士。在我的后一个示例中,您看不到show_something()
的主体所做的事情可能导致其暂停。但是,如果要使fetch_clean_text()
成为协程,不仅会使事情复杂化,而且可能还会降低性能。拥有另一个本身不执行任何I / O的协程几乎没有什么意义。有没有更好的办法?
参考方案
我看到这种设计的一个专业人士。在我后面的示例中,您看不到
show_something()的身体正在做某事,可能会导致其
悬挂。
这就是它如此设计的原因。编写并发代码可能非常棘手,并且异步作者认为始终显式标记代码中的挂起位置至关重要。
This article对其进行了详细说明(您可以从“ Get To the Point Already”段落开始)。
但是,如果我要使fetch_clean_text()成为协程,不仅
它使事情复杂化,但可能还会降低性能。
在处理I / O时,几乎只需要协程。与使用协程相比,I / O总是比开销花费更多的时间。因此,我想可以说-不,与您已经处理的I / O相比,使用协程不会浪费大量执行时间。
有没有更好的办法?
我只能建议的唯一方法是:将处理I / O(异步部分)的逻辑与其余代码(同步部分)分开。
from typing import Awaitable
def clean_text(text: str) -> str:
return text.strip(text)
async def fetch_text() -> Awaitable[str]:
return "text "
async def fetch_clean_text(text: str) -> Awaitable[str]:
text = await fetch_text()
return clean_text(text)
async def show_something():
something = await fetch_clean_text()
print(something)
Python GPU资源利用 - python我有一个Python脚本在某些深度学习模型上运行推理。有什么办法可以找出GPU资源的利用率水平?例如,使用着色器,float16乘法器等。我似乎在网上找不到太多有关这些GPU资源的文档。谢谢! 参考方案 您可以尝试在像Renderdoc这样的GPU分析器中运行pyxthon应用程序。它将分析您的跑步情况。您将能够获得有关已使用资源,已用缓冲区,不同渲染状态上…
Python sqlite3数据库已锁定 - python我在Windows上使用Python 3和sqlite3。我正在开发一个使用数据库存储联系人的小型应用程序。我注意到,如果应用程序被强制关闭(通过错误或通过任务管理器结束),则会收到sqlite3错误(sqlite3.OperationalError:数据库已锁定)。我想这是因为在应用程序关闭之前,我没有正确关闭数据库连接。我已经试过了: connectio…
python-docx应该在空单元格已满时返回空单元格 - python我试图遍历文档中的所有表并从中提取文本。作为中间步骤,我只是尝试将文本打印到控制台。我在类似的帖子中已经看过scanny提供的其他代码,但是由于某种原因,它并没有提供我正在解析的文档的预期输出可以在https://www.ontario.ca/laws/regulation/140300中找到该文档from docx import Document from…
Python:集群作业管理 - python我在具有两个阶段的计算群集(Slurm)上运行python脚本,它们是顺序的。我编写了两个python脚本,一个用于阶段1,另一个用于阶段2。每天早上,我检查所有第1阶段的工作是否都以视觉方式完成。只有这样,我才开始第二阶段。通过在单个python脚本中组合所有阶段和作业管理,是否有一种更优雅/自动化的方法?我如何知道工作是否完成?工作流程类似于以下内容:w…
Python-Excel导出 - python我有以下代码:import pandas as pd import requests from bs4 import BeautifulSoup res = requests.get("https://www.bankier.pl/gielda/notowania/akcje") soup = BeautifulSoup(res.cont…