簡體   English   中英

從Python同時調用腳本,將數據傳遞給每個腳本,並將數據返回到原始腳本

[英]Simultaneously Call a Script from Python, passing data to each, and Returning data to the original

我正在嘗試創建一個python腳本,該python腳本在傳入數組的同時調用其他5個python腳本以同時運行,然后5個腳本中的每個腳本對該數組執行操作,並將不同的數組返回給初始腳本。

然后,初始腳本會在5個數組返回值時實現,然后對這5個數組執行操作。

我認為解決方案類似於os.system(./script1.py arg1)os.system(./script2.py arg2)但我不確定如何進行。

您可以使用線程池並行運行所有命令。 我還切換到了獲取程序輸出的subprocess模塊:

import multiprocessing.pool
import subprocess as subp

def worker(script):
    proc = subp.Popen(script, shell=True, stdout=subp.PIPE, stderr=subp.PIPE)
    out, err = proc.communicate()
    return script, out, err, proc.returncode

scripts = ['./script1.py arg1', './script2.py arg2']
pool = multiprocessing.pool.ThreadPool(len(scripts))
for script, out, err, returncode in pool.map(worker, scripts):
    do your magic
pool.close()
pool.join()

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM