python3执行shell命令(基于subprocess.run)

python3执行复杂脚本命令 推荐模块为subprocess.run()

因此我们执行脚本就采用此函数,可以判断shell执行状态,可以获取到shell的执行结果。在日常使用中应该足矣

待执行命令

netstat -antlp | awk '{print $4,$5}'
shell的命令(获取到文本中.com结尾的字符)
p = subprocess.run(["grep -rn '.com$' %s | awk '{print $1, $3}'"%(path)],shell=True,stdout=subprocess.PIPE,stderr=subprocess.PIPE,check=False) 
print(p)

 

命令执行完成返回CompletedProcess实例

参数: shell=True  通过操作系统的shell执行命令

        stdout=subprocess.PIPE  shell命令执行的输出结果

        stderr=subprocess.PIPE shell命令执行错误时的输出结果,

        returncode=0 表示shell命令执行成功

通过python3获取shell命令执行的结果,对结果进行处理并存入数据库(实测有效)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
subprocess.runsubprocess.call都是Python中用于执行外部命令的模块subprocess中的函数。它们之间的区别如下: 1. 返回值类型: - subprocess.run:返回一个CompletedProcess对象,其中包含执行命令的结果信息,如返回码、输出和错误信息等。 - subprocess.call:返回一个整数值,表示命令的返回码。 2. 参数传递方式: - subprocess.run:可以通过传递参数args作为一个列表或字符串来执行命令。还可以使用其他参数来控制命令执行方式,如输入、输出、错误处理等。 - subprocess.call:只能通过传递参数args作为一个列表或字符串来执行命令。无法使用其他参数来控制命令执行方式。 3. 执行方式: - subprocess.run:默认情况下,以同步方式执行命令,即在子进程完成之前,主进程会一直等待。可以通过设置参数`shell=True`来以shell方式执行命令。 - subprocess.call:默认情况下,以同步方式执行命令,即在子进程完成之前,主进程会一直等待。无法以shell方式执行命令。 4. 输出处理: - subprocess.run:可以通过设置参数`capture_output=True`来捕获子进程的输出和错误信息,并作为CompletedProcess对象的属性进行访问。 - subprocess.call:无法直接捕获子进程的输出和错误信息。 5. 异常处理: - subprocess.run:如果命令执行失败(返回码非零),会引发CalledProcessError异常,可以通过捕获该异常来处理错误情况。 - subprocess.call:如果命令执行失败(返回码非零),不会引发异常,需要手动处理返回码来判断命令执行结果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

村长在路上

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值