python 批量执行同一个shell

使用python 可以进行多线程/进程同步进行某些操作。
可以使用subprocess库。这里主要使用的是check_call 和call两个方法。
开发的思路:首先按照单个文件执行的逻辑思路来写出你的基本的程序,第二步,将第一步中的程序添加到多线程或者多进程中来。
接下来是实际操作:

这是shell脚本的命令,文件:run.sh

name=$1
echo ${name}

接下来是python代码,文件:run.py

进程池方式:

from multiprocessing import Pool
from subprocess import *

app = ['111','222','333','444']

def exec_cmd(x):
	check_all(['./run.sh', x])

def run():
	with Pool(2) as po:
		po.map(exec_cmd, app)
		po.close()
		po.join()

if __name__ == '__main__':
	run()

线程方式:

import threading
from subprocess import *

app = ['111','222','333','444']

def exec_cmd(x):
	check_all(['./run.sh', x])

def run():
	for item in app:
		th = threading.Thread(target=exec_cmd, args=(item,))
		th.start()
		th.join()

if __name__ == '__main__':
	run()

两个程序执行的结果为:

> python3 run.py
111
222
333
4444
5555

以上作为记录。


版权声明:本文为hx_long原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。