我希望能够在不阻止的情况下获取文件列表,但我没有在documentation中看到这样做的方法。在执行程序中执行此操作的最佳方法是什么?
答案 0 :(得分:5)
是的,我认为这是最好的方式。我没有对列表文件进行本机非阻塞调用,因此您无法选择在线程/子进程中运行阻塞调用以获取非阻塞行为。以下是使用ProcessPoolExecutor
的简单示例。
import concurrent.futures
import asyncio
import os
def list_files():
return os.listdir(".")
def on_got_files(fut):
print("got files {}".format(fut.result()))
loop.stop()
def main():
with concurrent.futures.ProcessPoolExecutor() as executor:
fut = loop.run_in_executor(executor, list_files)
fut.add_done_callback(on_got_files)
print("Listing files asynchronously")
if __name__ == "__main__":
loop = asyncio.get_event_loop()
loop.call_soon(main)
loop.run_forever()
输出:
C:\Users\Dan\Desktop>python3 async.py
Listing files asynchronously
got files [<files are listed here>]