在没有Web服务器的情况下从本地主机获取文件

我想在没有 Web 服务器的情况下从本地主机异步获取文件。似乎可以使用 file:// 方案。以下代码示例取自文档,但显然它不起作用:


import aiohttp

import asyncio


async def fetch(session, url):

    async with session.get(url) as response:

        return await response.text()


async def main():

    async with aiohttp.ClientSession() as session:

        html = await fetch(session, 'file://localhost/Users/user/test.txt')

        print(html)


if __name__ == '__main__':

    loop = asyncio.get_event_loop()

    loop.run_until_complete(main())

如何让它工作?


我看到的一种方法是使用 run_in_executor 在单独的线程池中使用“curl file://path”,但我认为应该有一种方法可以修复代码


SMILET
浏览 140回答 1
1回答

犯罪嫌疑人X

如果需要获取本地文件的内容,可以使用普通的 Python 内置来完成,例如:with open('Users/user/test.txt') as rd:    html = rd.read()如果文件不是很大,并且存储在本地文件系统上,您甚至不需要使其异步,因为读取它的速度足够快,不会干扰事件循环。如果文件很大或由于其他原因读取速度可能很慢,则应通读它以防止它阻止其他 asyncio 代码。例如(未经测试):run_in_executordef read_file_sync(file_name):    with open('Users/user/test.txt') as rd:        return rd.read()async def read_file(file_name):    loop = asyncio.get_event_loop()    html = await loop.run_in_executor(None, read_file_sync, file_name)    return html
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

Python