1. ホーム
  2. python

[解決済み] スレッド化したり、別のファイルやスクリプトを書くことなく、サブプロセスで関数を実行することは可能ですか?

2023-03-08 10:45:47

質問

import subprocess

def my_function(x):
    return x + 100

output = subprocess.Popen(my_function, 1) #I would like to pass the function object and its arguments
print output 
#desired output: 101

私は、別々のスクリプトを使用してサブプロセスを開くことについてのドキュメントしか見つけられませんでした。誰か関数オブジェクトを渡す方法、あるいは関数コードを渡す簡単な方法を知っていますか?

どのように解決するのですか?

マルチプロセッシングモジュールのようなものをお探しなのでしょう。

http://docs.python.org/library/multiprocessing.html#the-process-class

subprocess モジュールはプロセスを生成し、その入出力で何かを行うためのもので、関数を実行するためのものではありません。

ここでは multiprocessing のバージョンです。

from multiprocessing import Process, Queue

# must be a global function    
def my_function(q, x):
    q.put(x + 100)

if __name__ == '__main__':
    queue = Queue()
    p = Process(target=my_function, args=(queue, 1))
    p.start()
    p.join() # this blocks until the process terminates
    result = queue.get()
    print result