これは一般的な問題のようです。例を参照してください。 RuntimeError:このイベントループはすでにPythonで実行されています
しかし、私の場合、イベントループを1回だけ開始しています。また、この例は指示 here に直接従います:
import asyncio
loop = asyncio.get_event_loop()
async def coroutine():
print("hey")
await asyncio.sleep(1)
print("ho")
return 1
async def main():
tasks = []
for i in range(2):
tasks.append(asyncio.ensure_future(coroutine()))
await asyncio.gather(*tasks)
results = loop.run_until_complete(main())
loop.close()
これはエラーメッセージを出力し、print()の出力はコルーチンで呼び出されます。
---------------------------------------------------------------------------
RuntimeError Traceback (most recent call last)
<ipython-input-1-f4a74fbfac46> in <module>
16 await asyncio.gather(*tasks)
17
---> 18 results = loop.run_until_complete(asyncio.gather(*tasks))
19 loop.close()
~/anaconda3/envs/keras_dev/lib/python3.6/asyncio/base_events.py in run_until_complete(self, future)
453 future.add_done_callback(_run_until_complete_cb)
454 try:
--> 455 self.run_forever()
456 except:
457 if new_task and future.done() and not future.cancelled():
~/anaconda3/envs/keras_dev/lib/python3.6/asyncio/base_events.py in run_forever(self)
407 self._check_closed()
408 if self.is_running():
--> 409 raise RuntimeError('This event loop is already running')
410 if events._get_running_loop() is not None:
411 raise RuntimeError(
RuntimeError: This event loop is already running
hey
hey
ho
ho
そして、結果変数は未定義のままです。
コルーチンのリストをスピンアップして、その出力を正しく収集するにはどうすればよいですか?
いくつかのアップグレードを行った後も、この問題に遭遇しました。 tornado
パッケージが原因である可能性が最も高いことがわかりました。 tornado>=5.0
がある場合、ノートブックでイベントループを実行すると競合が発生します。詳細な議論 here がありますが、現時点での解決策はpip install tornado==4.5.3
でダウングレードすることです。