本篇內(nèi)容介紹了“tornado執(zhí)行asyncio異步報錯run_forever assert self._self_reading_future is None怎么解決”的有關(guān)知識,在實(shí)際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!
創(chuàng)新互聯(lián)建站專注于網(wǎng)站建設(shè),為客戶提供成都網(wǎng)站制作、成都網(wǎng)站建設(shè)、外貿(mào)營銷網(wǎng)站建設(shè)、網(wǎng)頁設(shè)計開發(fā)服務(wù),多年建網(wǎng)站服務(wù)經(jīng)驗,各類網(wǎng)站都可以開發(fā),成都品牌網(wǎng)站建設(shè),公司官網(wǎng),公司展示網(wǎng)站,網(wǎng)站設(shè)計,建網(wǎng)站費(fèi)用,建網(wǎng)站多少錢,價格優(yōu)惠,收費(fèi)合理。
報錯信息:python38\lib\asyncio\windows_events.py", line 314 run_forever assert self._self_reading_future is None
解決如下:
需要引入nest_asyncio,代碼如下:
import nest_asyncio
nest_asyncio.apply()
封裝執(zhí)行多個異步方法并返回結(jié)果
import asyncio import nest_asyncio from tornado.platform.asyncio import to_asyncio_future nest_asyncio.apply() async def asyncio_all_task(*fuc_list): ''' 執(zhí)行多個異步方法 ''' tasks=[] for t in fuc_list: tasks.append(asyncio.ensure_future(t)) result= asyncio.get_event_loop().run_until_complete(to_asyncio_future(asyncio.gather(*tasks))) # asyncio.get_event_loop().run_until_complete(asyncio.wait(tasks)) return result def asyncio_all_task2(*fuc_list): result=[] loop = asyncio.get_event_loop() res= loop.run_until_complete(asyncio.wait(fuc_list)) for r in res[0]: result.append(r._result) return result
“tornado執(zhí)行asyncio異步報錯run_forever assert self._self_reading_future is None怎么解決”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識可以關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!