我是靠谱客的博主 怕孤单泥猴桃,最近开发中收集的这篇文章主要介绍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

以上作为记录。

最后

以上就是怕孤单泥猴桃为你收集整理的python 批量执行同一个shell的全部内容,希望文章能够帮你解决python 批量执行同一个shell所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(43)

评论列表共有 0 条评论

立即
投稿
返回
顶部