我们通常可以使用os模块的命令进行执行cmd
方法一:os.system
1
2
3
4
5
|
os.system(执行的命令)
# 源码
def system( * args, * * kwargs): # real signature unknown
""" Execute the command in a subshell. """
pass
|
方法二:os.popen(执行的命令)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
|
os.popen(执行的命令)
# 源码
def popen(cmd, mode = "r" , buffering = - 1 ):
if not isinstance (cmd, str ):
raise TypeError( "invalid cmd type (%s, expected string)" % type (cmd))
if mode not in ( "r" , "w" ):
raise ValueError( "invalid mode %r" % mode)
if buffering = = 0 or buffering is None :
raise ValueError( "popen() does not support unbuffered streams" )
import subprocess, io
if mode = = "r" :
proc = subprocess.Popen(cmd,
shell = True ,
stdout = subprocess.PIPE,
bufsize = buffering)
return _wrap_close(io.TextIOWrapper(proc.stdout), proc)
else :
proc = subprocess.Popen(cmd,
shell = True ,
stdin = subprocess.PIPE,
bufsize = buffering)
return _wrap_close(io.TextIOWrapper(proc.stdin), proc)
|
两者区别
- system只把能输入的内容给返回回来了,其中代码 0 表示执行成功。但是我们没有办法获取输出的信息内容
- popen可以获取输出的信息内容,它是一个对象,可以通过 .read() 去读取
以上就是用Python 执行cmd命令的详细内容,更多关于python 执行cmd命令的资料请关注服务器之家其它相关文章!
原文链接:https://www.cnblogs.com/poloyy/p/12641547.html