質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
並列処理

複数の計算が同時に実行される手法

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

Q&A

解決済

2回答

2507閲覧

Pythonでの並列処理方法

blacktt_red

総合スコア11

並列処理

複数の計算が同時に実行される手法

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

0グッド

1クリップ

投稿2020/09/23 03:33

編集2020/09/23 03:50

前提・実現したいこと

Python での並列処理について下記URLを参考に検討しております。
https://qiita.com/castaneai/items/9cc33817419896667f34#%E3%82%B9%E3%83%AC%E3%83%83%E3%83%89%E3%83%97%E3%83%BC%E3%83%AB-concurrentfutures

下記コードをjupyter 上で実行したところtest1の出力(test1)しかprint
されないのですが、原因はなんでしょうか。

該当のソースコード

Python

1import concurrent.futures 2import time 3 4def test1(): 5 while True: 6 print("test1") 7 time.sleep(1) 8 9def test2(): 10 while True: 11 print("test2") 12 time.sleep(1) 13if __name__ == "__main__": 14 executor = concurrent.futures.ProcessPoolExecutor(max_workers=2) 15 executor.submit(test1()) 16 executor.submit(test2()) 17 18 19

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

ベストアンサー

公式リファレンス(https://docs.python.org/ja/3/library/concurrent.futures.html#processpoolexecutor)によると

__main__ モジュールはワーカサブプロセスでインポート可能でなければなりません。 すなわち、 ProcessPoolExecutor は対話的インタープリタでは動きません。

とあるので、ProcessPoolExecutorはjupyterでは使えないのではないでしょうか。

こちらの質問に対する回答も参考になりそうです。

投稿2020/09/23 06:27

bsdfan

総合スコア4794

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

blacktt_red

2020/09/23 23:14

回答頂きありがとうございます。下記指摘事項に加え、Python上で実行することで問題解決致しました。
guest

0

executor.submit(test1())

これは

executor.submit(test1)

じゃないでしょうか

#他も同じ

投稿2020/09/23 03:41

編集2020/09/23 03:42
y_waiwai

総合スコア88042

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

blacktt_red

2020/09/23 03:54

回答頂きありがとうございます。 検討してみたのですが、test1,2ともに実行されませんでした。
otn

2020/09/23 04:21

修正後のコードと実行結果を載せましょう。
blacktt_red

2020/09/23 04:30

修正後コード executor.submit(test1) executor.submit(test2) 結果 表示なし 如何でしょうか。よろしくお願い致します。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問