python执行shell命令
import os
import subprocess
def run_cmd_system(command):
try:
print(f"通过system运行run command: {command}")
os.system(command)
except Exception as e:
print(f"命令运行失败!{e}")
raise e
# 第一种,通过os.system执行命令,特点是直接将执行的命令打印出来了,根本不用我们print,但是缺点也很明显,就是不是一个我们可以使用的数据结构,所以这个命令并不实用
def run_cmd_popen(command):
try:
print(f"通过popen运行run command: {command}")
os.popen(command)
print("os.popen什么都没打印出来")
print(os.popen(command))
print(os.popen(command).readlines())
print(type(os.popen(command).readlines()))
except Exception as e:
print(f"命令运行失败!{e}")
raise e
# 第二种,通过popen来执行命令,特点是我们执行命令并不会打印任何信息,实用print打印也是一个内存地址而已,需要实用readlines读取,读取出来是一个list,方便处理
# 如果是小程序,可以尝试用这个。
def run_cmd_subprocess(command):
try:
print(f"通过subprocess运行run command: {command}")
res = subprocess.Popen(command, shell=True, stdout=subprocess.PIPE)
res.wait() # 等待结果返回
result = res.stdout.readlines()
print(type(result))
print(result)
except subprocess.CalledProcessError as e:
print(f"命令运行失败!{e}")
raise e
return result
# 第三种,通过subprocess来执行命令,subprocess这个模块来产生子进程,并连接到子进程的标准输入/输出/错误中去,还可以得到子进程的返回值
# subprocess意在替代其他几个老的模块或者函数,比如:os.system os.spawn* os.popen* popen2.* commands.*
# 举一个例子,你的主进程是一条源源不断的河流,这个时候你的主进程想要执行一条指令,想要做一些其他的事情,那这个时候,主进程这条河流又不想断流(因为要抽身做其他的事情),那怎么办,最好的办法就是再来一个子进程
# 这种方法是最被推崇的。
if __name__ == "__main__":
run_cmd_subprocess("ls")
run_cmd_system("ls")
run_cmd_popen("ls")
结果
通过subprocess运行run command: ls
<class 'list'>
[b'__init__.py\n', b'__pycache__\n', b'commandrun.py\n', b'fastapiOne.py\n', b'fastapiTwo.py\n', b'logged.py\n', b'maoli.py\n']
通过system运行run command: ls
__init__.py
__pycache__
commandrun.py
fastapiOne.py
fastapiTwo.py
logged.py
maoli.py
通过popen运行run command: ls
os.popen什么都没打印出来
<os._wrap_close object at 0x7fa3fd242820>
['__init__.py\n', '__pycache__\n', 'commandrun.py\n', 'fastapiOne.py\n', 'fastapiTwo.py\n', 'logged.py\n', 'maoli.py\n']
<class 'list'>