使用python自动化脚本执行shell命令,提前两小时下班(5)
off999 2024-10-11 14:05 22 浏览 0 评论
今天我们来学习如何通过python脚本执行linux 操作系统命令,通过前面几期的学习,我们基本已经可以控制操作系统的目录和文件,切换到特定路径下,获取系统环境变量,获取用户命令行变量,跟用户进行入参交互。通过正则表达式过滤和加工我们需要的数据。
这次,我们来补遗,再次讲讲如何使用python脚本执行Linux shell脚本命令。
有同学可能要问了,我直接写shell 不就完了,为啥需要多此一举用python调用shell呢?
python 的优势在哪里?
- python 编码调试更加容易,灵活性更高,变量有一定的类型。
- python 更加适合大规模,模块化的自动化脚本编写。
因此,目前工作中,涉及自动化脚本的场景,多用python替代shell。
于是,使用python执行shell命令,就是替换中的关键功能了,实际上前面有一期已经给大家介绍了四种python执行shell脚本命令的方式。
本次,我们聚焦于subprocess 这种官方推荐的形式,并给大家及进行详细介绍。
先看一个简单的示例:
import subprocess
>>> subprocess.run(["date"])
Fri Mar 22 21:16:26 CST 2024
// 通过python执行date shell命令,结果打印
CompletedProcess(args=['date'], returncode=0)
// 返回了一个CompletedProcess对象
// 可以看到返回值returncode 为0
// 代表正确执行返回
如果我们执行的语句出现错误会发生什么呢?
>>> result = subprocess.run(["ls", "file_not_exists"])
ls: cannot access 'file_not_exists': No such file or directory
>>> print(result.returncode)
2 // 我们发现,执行ls指令,失败后返回非0值
上面的一些shell命令,包括chmod, ls, date 等,我们一般只关心这些命令调用后是否成功,我们不需要对执行结果进行进一步处理时,直接判断执行返回值的returncode是否为0就足够了。
但是如果有一些shell命令,我们执行后,需要对执行结果进行进一步过滤,处理,获取一些有用信息时,那么上面的方式就不适用了。
那应该怎么办呢?
>>> result =
subprocess.run(["host", "8.8.8.8"], stdout=subprocess.PIPE)
>>> print(result.returncode)
0
>>> print(result.stdout)
b'8.8.8.8.in-addr.arpa domain name pointer dns.google.\n'
// 我们可以使用stdout属性或者capture_out=True
// 然后通过result.stdout获取到执行结果
host可以根据入参的ip地址,进行域名获取功能。
这里有个小tips,大家知道那个stdout显示结果的字符串前面为啥有个b不?
其实这代表的是,这个字符串它不是一个python标准的字符串,而是字节数组类型。
如果想进一步获取到python标准的字符串,可以使用decode方法。
>>> ret_list = result.stdout.decode().split()
// decode 之后split,存储为列表
>>> print(ret_list)
['8.8.8.8.in-addr.arpa', 'domain', 'name', 'pointer', 'dns.google.']
// 打印结果
那么如果我们执行某个shell指令错误,如何获取错误结果呢?答案是使用stderr。
示例如下:
>>> result = subprocess
.run(["rm", "does_not_exists"],
stderr=subprocess.PIPE, stdout=subprocess.PIPE)
// 想删除一个不存在的文件
>>> print(result.returncode)
1
>>> print(result.stdout)
b''
// 执行结果为空,因为出现错误了
>>> print(result.stderr)
b"rm: cannot remove 'does_not_exists': No such file or directory\n"
// 打印错误结果在stderr中
然后我们在学会了上面的基础使用方法后,考虑一种场景。
场景示例:
- 我们想执行一个自己的二进制程序,需要把这个程序的可执行文件路径添加到操作系统的环境变量中去。
如何实现这个功能呢?
示例如下:
>>> import os
>>> import subprocess
>>> my_env_to_run_app = os.environ.copy()
>>> my_env_to_run_app
= os.pathsep.join(["/opt/myapp/",
my_env_to_run_app["PATH"]])
>>> result = subprocess.run(["myapp"], env = my_env_to_run_app)
我们通过os.environ.copy做环境变量的拷贝,然后添加自己的环境变量进去,然后在subprocess执行时,指定环境变量即可。
需要注意的是,subprocess 默认是启动了一个子线程去执行shell命令的,从上面的copy环境变量也可以看出,如果想执行一些命令直接作用在当前shell 中,则必须指定shell。
我们证明一下这件事情:
result = subprocess.run(["export", "Fruit=Apple"], shell=True)
// 导出一个环境变量Fruit
>>> print(result.returncode)
0 // 执行成功
>>> print(os.environ["LOGNAME"])
chen // 正常系统环境变量
>>> print(os.environ["Fruit"])
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "/usr/lib/python3.6/os.py", line 669, in __getitem__
raise KeyError(key) from None
KeyError: 'Fruit'
// 发现通过subprocess export
// 的变量不在当前shell中,无法获取到
好的,今天就先讲到这里,你的关注就是我分享的动力,希望大家关注并给我留言,任何想听的想看的,都可以留言告诉我,给大家分享。
相关推荐
- 还不会deepseek部署到本地?这篇教程手把手教会你
-
一、为什么要把DeepSeek部署到本地?新手必看的前置知识近期很多读者在后台询问AI工具本地部署的问题,今天以国产优质模型DeepSeek为例,手把手教你实现本地化部署。本地部署有三大优势:数据隐私...
- 推荐个超实用的Python标准库pathlib,玩转路径操作
-
pathlib学习Python时,尤其是在进行文件操作和数据处理时,经常会处理路径问题。最常用和常见的是os.path模块,它将路径当做字符串进行处理,如果使用不当可能导致难以察觉的错误,而且...
- python中文件读写操作最佳实践——使用 os.path 进行路径操作
-
在Python中处理文件路径时,使用os.path模块比直接使用字符串拼接更加安全、可靠且跨平台。下面我将详细解释为什么以及如何使用os.path进行路径操作。为什么不应该使用字符串拼接?#不推荐的...
- Python如何获取当前文件所在目录的完整路径
-
在编程的过程中,我们常常会遇到需要获取当前文件所在目录完整路径的需求。那具体该怎么做呢?这是在众多开发者群体中备受关注的一个问题,就像在问答平台上“/questions/3430372/how-d...
- python编程之神经网络篇(python的神经网络编程)
-
#头条创作挑战赛#神经网络发展到今天大致经历了2次兴起和2次衰落,1943年心理学家McCulloch(麦卡洛克)和数学家Pitts(皮茨)参考生物神经系统的工作原理,首次提出建立了MP神经元模型。其...
- 详解Python整数类型的按位运算(在python中整数)
-
在Python编程中,按位运算是直接对整数的二进制位进行操作的底层运算,虽然不如逻辑运算常见,但在处理位掩码、状态标志、底层算法优化等场景中至关重要。本文将从基础概念到高级应用,全面解析Python整...
- 强化学习的改进只是「噪音」?最新预警:冷静看待推理模型进展
-
机器之心报道编辑:蛋酱、+0「推理」已成为语言模型的下一个主要前沿领域,近期学术界和工业界都取得了突飞猛进的进展。在探索的过程中,一个核心的议题是:对于模型推理性能的提升来说,什么有效?什么无效?De...
- 了解python3新特性-3(python3介绍)
-
以下是Python3的其他一些特性:改进了asyncio.run():Python3.7中对asyncio.run()函数进行了改进,可以方便地处理异步任务异常。新增了typing....
- python GIL全局解释器锁原理、功能及应用示例
-
GIL(GlobalInterpreterLock)是Python解释器中的一个机制,它是一把全局锁,用于在同一时间内限制只有一个线程执行Python字节码。以下是GIL的原理、功能以及5个示例:...
- python3-运算符优先级(python语言运算符优先级)
-
#挑战30天在头条写日记#Python运算符优先级以下列出了从最高到最低优先级的所有运算符,相同单元格内的运算符具有相同优先级。运算符均指二元运算,除非特别指出。相同单元格内的运算符从左至右分组...
- 如何在 Python 中使用 Notion API?
-
如何在Python中使用NotionAPI并自动编辑数据库。设置NotionAPI和数据库首先,让我们在Notion板中创建一个完整的页面数据库。在本文中,我使用了一个来自我的一个数据库的真实示...
- 一文了解 Python 的临时文件模块(python tmpfile)
-
Python的Tempfile模块是用于创建临时文件和文件夹的标准库。当我们需要临时存储数据时,可以创建临时文件,这些文件位于单独的目录中,该目录因操作系统而异,并且这些文件的名称是唯一的。在...
- 一文带您精通Python 集合(Set):8个不可不知的技巧及示例
-
在Python中,集合(Set)与列表(List)、字典(Dict)、元组(Tuple)一起构成了基本的数据结构。集合以其独特的无序性和元素唯一性,在处理数据时具有独特的优势。然而,很多人对集合的...
- 数据类型的"变形记":解锁Python数据处理效率的关键钥匙
-
在日常编程中,数据就像流动的河水,而数据类型就是塑造河道的模具。当我们从用户输入、文件读取或网络请求中获取数据时,往往需要像侦探一样验证它们的真实身份,再像魔术师一样将它们转换成需要的形态。这就是数据...
- 大学 Python 程序设计实验报告:基于组合数据类型
-
一、实验目的编写Python程序,实现对简单文本的处理,掌握列表、元组、字典等组合类型的应用。二、实验要求掌握字符串的输入和输出。掌握使用切片的方式访问字符串中的值。掌握常见的字符串内建函数的应用。...
你 发表评论:
欢迎- 一周热门
-
-
python 3.8调用dll - Could not find module 错误的解决方法
-
加密Python源码方案 PyArmor(python项目源码加密)
-
Python3.8如何安装Numpy(python3.6安装numpy)
-
大学生机械制图搜题软件?7个受欢迎的搜题分享了
-
编写一个自动生成双色球号码的 Python 小脚本
-
免费男女身高在线计算器,身高计算公式
-
将python文件打包成exe程序,复制到每台电脑都可以运行
-
Python学习入门教程,字符串函数扩充详解
-
Python数据分析实战-使用replace方法模糊匹配替换某列的值
-
Python进度条显示方案(python2 进度条)
-
- 最近发表
- 标签列表
-
- python计时 (54)
- python安装路径 (54)
- python类型转换 (75)
- python进度条 (54)
- python的for循环 (56)
- python串口编程 (60)
- python写入txt (51)
- python读取文件夹下所有文件 (59)
- java调用python脚本 (56)
- python操作mysql数据库 (66)
- python字典增加键值对 (53)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python qt (52)
- python人脸识别 (54)
- python斐波那契数列 (51)
- python多态 (60)
- python命令行参数 (53)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- centos7安装python (53)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)