我们通常可以使用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