os.system与os.popen

本文对比了Python中os.system与os.popen两种调用Shell的方法。os.system(cmd)返回脚本退出状态码,用于判断执行是否成功;os.popen(cmd)则返回脚本执行的输出内容,适用于获取脚本输出数据的场景。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

os.system 与 os.popen

​ Python调用Shell,有两种方法:os.system(cmd)或os.popen(cmd)脚本执行过程中的输出内容。实际使用时视需求情况而选择。

区别:

  • os.system(cmd)的返回值是脚本的退出状态码,只会有0(成功),1,2
  • os.popen(cmd)返回脚本执行的输出内容作为返回值

os.system(cmd):

该方法在调用完shell脚本后,返回一个信号代码。

>>> os.system(``'md5sum /root/all.sql'``)
7735d611ebce91ebb4c7acc4747a8b67`  `/``root``/``all``.sql
0`      `#返回的信号代码  0(成功)

os.popen(cmd):

这种调用方式是通过管道的方式来实现,函数返回一个file-like的对象,里面的内容是脚本输出的内容(可简单理解为echo输出的内容)。使用os.popen调用脚本的情况:

>>> md5_value ``=` `os.popen(``'md5sum /root/all.sql'``)    ``#将结果赋值给变量
>>> ``print``(``type``(md5_value))          ``#查看类型
<``class` `'os._wrap_close'``>
>>> ``print``(md5_value.read().split()[``0``])         ``#取值
7735d611ebce91ebb4c7acc4747a8b67

明显地,像调用”ls”这样的shell命令,应该使用popen的方法来获得内容

### 代码概述 该段代码使用 `os.system` 和 `os.popen` 分别演示如何执行系统命令和捕获命令输出。我们将展示如何使用这两种方法来ping特定IP地址(192.168.3.107),并捕获或检查命令的输出结果。 ### 代码解析 #### 使用 `os.system` ```python import os import time def ping_ip_with_system(ip, retries=2): attempt = 0 while attempt < retries: response = os.system(f"ping -c 1 {ip}") if response == 0: print(f"{ip} 可以访问") return else: attempt += 1 print(f"{ip} 暂时无法访问,等待3秒后重试...(第 {attempt} 次)") time.sleep(3) print(f"超过 {retries} 次尝试,{ip} 无法访问") # 示例调用 ping_ip_with_system("192.168.3.107") ``` - **`os.system()`**:执行系统命令并返回命令的退出状态码(0表示成功,非0表示失败)。它不会捕获命令的输出。 #### 使用 `os.popen` ```python import os import time def ping_ip_with_popen(ip, retries=2): attempt = 0 while attempt < retries: with os.popen(f"ping -c 1 {ip}") as pipe: output = pipe.read() if "1 packets transmitted, 1 received" in output: print(f"{ip} 可以访问,输出如下:\n{output}") return else: attempt += 1 print(f"{ip} 暂时无法访问,等待3秒后重试...(第 {attempt} 次)") time.sleep(3) print(f"超过 {retries} 次尝试,{ip} 无法访问") # 示例调用 ping_ip_with_popen("192.168.3.107") ``` - **`os.popen()`**:执行系统命令并返回一个文件对象,可以通过 `.read()` 方法读取命令的输出内容。 - **`with` 语句**:确保文件对象在使用完毕后自动关闭,避免资源泄露。 ### 知识点 - **`os.system()`**:用于执行系统命令并返回命令的退出状态码,适合简单命令执行。 - **`os.popen()`**:用于执行系统命令并捕获命令的输出,适合需要获取命令输出的情况。 - **`with` 语句**:确保文件对象在使用完毕后自动关闭,避免资源泄露。 ### 注意事项 - 此代码适用于类Unix系统(如Linux和macOS)。对于Windows系统,`ping`命令的参数应改为`-n 1`。 - `os.popen()` 已经被 `subprocess` 模块取代,推荐在新代码中使用 `subprocess` 模块以获得更好的灵活性和安全性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值