cmd命令调用,Python下调用Linux的Shell命令的艺术

python cmd命令调用

关于python调用cmd命令:

重中之重介绍三种办法:

1.python的OS模块。

  OS模块调用CMD命令有二种方法:os.popen(),os.system().
都是用当下经过来调用。

  os.system是无法取得再次来到值的。当启动截至后继之往上面执行顺序。用法如:OS.system(“ipconfig”).

  OS.popen带重返值的,怎么着获得再次回到值。如

  p=os.popen(cmd)

  print p.read().获得的是个字符串。

  那四个都以用当下历程来调用,也正是说它们都以阻塞式的。

cmd命令调用,Python下调用Linux的Shell命令的艺术。2.管道subprocess模块。

  运营规律会在当下历程下边产生子进度。

  sub=subprocess.Popen(cmd,shell=True,stdout=subprocess.PIPE)

  sub.wait()

  print sub.read()

python cmd命令调用,pythoncmd命令

关于python调用cmd命令:

重视介绍三种方法:

1.python的OS模块。

  OS模块调用CMD命令有二种方式:os.popen(),os.system().
都以用当下进程来调用。

  os.system是力不从心得到重回值的。当运维停止后随即往下边执行顺序。用法如:OS.system(“ipconfig”).

  OS.popen带重返值的,怎么着收获重临值。如

  p=os.popen(cmd)

  print p.read().获得的是个字符串。

  那五个都以用当下历程来调用,相当于说它们都以阻塞式的。

2.管道subprocess模块。

  运营规律会在此时此刻经过下边产生子进度。

  sub=subprocess.Popen(cmd,shell=True,stdout=subprocess.PIPE)

  sub.wait()

  print sub.read()

 

cmd命令调用,Python下调用Linux的Shell命令的艺术。 cmd命令调用,pythoncmd命令
关于python调用cmd命令: 主要介绍三种格局: 壹.python的OS模块。
OS模块调用CMD命令有两种办法:os.popen(),os.sy…

常用的二种方法:

神迹难免要求向来调用Shell命令来成功部分相比较简单的操作,比如mount3个文件系统之类的。那么大家选取Python怎样调用Linux的Shell命令?上面来介绍两种常用的法子:

1.python的OS模块。

1. os 模块

  OS模块调用CMD命令有二种艺术:os.popen(),os.system().
都以用当下进度来调用。

1.1. os模块的exec方法族

  os.system是无能为力得到重返值的。当运维截止后接着往上边执行顺序。用法如:OS.system(“ipconfig”).

Python的exec系统方法同Unix的exec系统调用是相同的。这么些艺术适用于在子进度中调用外部程序的图景,因为外部程序会交替当前经过的代码,不会回到。(
这一个看了点 help(os)  –> search “exec”
的连锁介绍,不过没太搞精通咋使用)

  OS.popen带重临值的,怎么样赢得重临值。如

1.2. os模块的system方法

  p=os.popen

system方法会创造子进度运转外部程序,方法只回去外部程序的运作结果。那几个艺术相比适用于外部程序尚未出口结果的景况。

  print p.read().获得的是个字符串。

>>> import os 
>>> os.system("echo \"Hello World\"") # 直接使用os.system调用一个echo命令 
Hello World   ——————> 打印命令结果 
0     ——————> What's this ? 返回值? 
>>> val = os.system("ls -al | grep \"log\" ") # 使用val接收返回值 
-rw-r--r-- 1 root  root  6030829 Dec 31 15:14 log ——————> 此时只打印了命令结果 
>>> print val    
0     ——————> 注意,此时命令正常运行时,返回值是0 
>>> val = os.system("ls -al | grep \"log1\" ") 
>>> print val   
256     ——————> 使用os.system调用一个没有返回结果的命令,返回值为256~ 
>>> 

  那多少个都是用当下经过来调用,也正是说它们都是阻塞式的。

在意:上边说了,此措施脂肪会外部程序的结果,也正是os.system的结果,所以假设你想接受命令的重临值,接着向下看~

  执行多条命令时,通过“&&”、“:”或“||”来实行划分,“:”命令会顺序执行下去,“&&”命令会顺序执行下去蒙受错误命令停止;“||”命令会顺序执行下去境遇成功命令甘休,前面包车型大巴指令不会进行

1.3. os模块的popen方法

2.管道subprocess模块。

当需求取得外部程序的输出结果时,本办法丰盛有效。比如动用urllib调用Web
API时,供给对取得的多少实行拍卖。os.popen(cmd)
要赢得传令的出口内容,只需再调用下read()或readlines()等
如a=os.popen(cmd).read()

  运营原理会在现阶段历程下边发生子进程。

>>> os.popen('ls -lt')     # 调用os.popen(cmd)并不能得到我们想要的结果 
<open file 'ls -lt ', mode 'r' at 0xb7585ee8> 
>>> print os.popen('ls -lt').read()  # 调用read()方法可以得到命令的结果 
total 6064 
-rwxr-xr-x 1 long  long   23 Jan 5 21:00 hello.sh 
-rw-r--r-- 1 long  long   147 Jan 5 20:26 Makefile 
drwxr-xr-x 3 long  long   4096 Jan 2 19:37 test 
-rw-r--r-- 1 root  root  6030829 Dec 31 15:14 log 
drwxr-xr-x 2 long  long   4096 Dec 28 09:36 pip_build_long 
drwx------ 2 Debian-gdm Debian-gdm 4096 Dec 23 19:08 pulse-gylJ5EL24GU9 
drwx------ 2 long  long   4096 Jan 1 1970 orbit-long 
>>> val = os.popen('ls -lt').read()  # 使用变量可以接收命令返回值 
>>> if "log" in val:     # 我们可以使用in来判断返回值中有木有一个字符串 
...  print "Haha,there is the log" 
... else: 
...  print "No,not happy" 
... 
Haha,there is the log 

  sub=subprocess.Popen(cmd,shell=True,stdout=subprocess.PIPE,stdin= ,
…)

2. commands 模块

  sub.wait()

采纳commands模块的getoutput方法,那种方法同popend的不同在于popen再次回到的是三个文书句柄,而本办法将表面程序的出口结果当作字符串重返,很多情形下用起来要更方便些。
驷不比舌格局: 

  print sub.read()

  1. commands.getstatusoutput(cmd)         返回(status, output)
  2. commands.getoutput(cmd)                   只回去输出结果
  3. commands.getstatus(file)                     重返ls -ld
    file的执行结果字符串,调用了getoutput,不提出使用此方法
long@zhouyl:/tmp/tests$ python 
Python 2.7.3 (default, Jan 2 2013, 16:53:07) 
[GCC 4.7.2] on linux2 
Type "help", "copyright", "credits" or "license" for more information. 
>>> import commands 
>>> commands.getstatusoutput('ls -lt')  # 返回(status, output) 
(0, 'total 5900\n-rwxr-xr-x 1 long long  23 Jan 5 21:34 hello.sh\n-rw-r--r-- 1 long long  147 Jan 5 21:34 Makefile\n-rw-r--r-- 1 long long 6030829 Jan 5 21:34 log') 
>>> commands.getoutput('ls -lt')   # 返回命令的输出结果(貌似和Shell命令的输出格式不同哈~) 
'total 5900\n-rwxr-xr-x 1 long long  23 Jan 5 21:34 hello.sh\n-rw-r--r-- 1 long long  147 Jan 5 21:34 Makefile\n-rw-r--r-- 1 long long 6030829 Jan 5 21:34 log' 
>>> commands.getstatus('log')    # 调用commands.getoutput中的命令对'log'文件进行相同的操作 
'-rw-r--r-- 1 long long 6030829 Jan 5 21:34 log' 
>>> 

3. subprocess模块

依照Python官方文书档案表达,subprocess模块用于代替上边那么些模块。有三个用Python达成的并行ssh工具—mssh,代码相当粗略,然而很有意思,它在线程中调用subprocess运维子进度来工作。

>>> from subprocess import call 
>>> call(["ls", "-l"]) 

subprocess与system比较的优势是它越来越灵敏(你能够获得专业输出,标准错误,“真正”的意况代码,更加好的错误处理,等..)。作者认为利用os.system已不合时宜,或将要过时。

四. 众方法的比较以及总计

4.1. 关于 os.system

os.system("some_command with args")将下令以及参数字传送递给你的系统shell,那很好,因为您能够用那种措施同时运行三个指令并且能够设置管道以及输入输出重定向。比如:
os.system(“some_command < input_file | another_command >
output_file”)
不过,就算这很有利,然则你须要手动处理shell字符的转义,比如空格等。其它,那也不得不让你运转简单的shell命令而且不能够运作外部程序。

4.2. 关于os.popen

使用stream = os.popen(“some_command with
args”)也能做与os.system壹样的事,与os.system区别的是os.popen会给您贰个像文件的靶子从而你能够使用它来访问哪个程序的科鲁班入、输出。而且popen还有八个变种都以在I/O处理上有轻微分裂。假诺你通过1个字符串传递全数东西,你的下令会传递给shell;假若您通过二个列表传递他们,你绝不操心逃避任何事。

4.3. 关于subprocess.popen

subprocess模块的Popen类,意图作为os.popen的代表,不过因为其很圆满所以比os.popen要来得某个复杂,使用起来须要学习啊~~。
譬如说您能够使用  print 波普n(“echo Hello World”, stdout=PIPE,
shell=True).stdout.read()  来代替  print os.popen(“echo Hello
World”).read()。不过比较它应用三个集合的类包含四中差别的popen函数仍旧不错的。

4.4. 关于subprocess.call

subprocess模块的call函数。它基本上就像是Popen类并都选取相同的参数,不过它只简单的等候命令完毕并给您回到代码。比

如:

return_code = subprocess.call("echo Hello World", shell=True)

os模块中还有C中那么的fork/exec/spawn函数,然而本身不建议直接动用它们。subprocess恐怕一发吻合您。

以上就是本文的全体内容,希望对我们的读书抱有帮衬,也愿意我们多多协理脚本之家。

www.5929.com,您大概感兴趣的文章:

  • python+influxdb+shell编写区域网络情形表
  • Python设置在shell脚本中自动补全作用的措施
  • python和shell监察和控制linux服务器的事无巨细代码
  • python和shell获取文本内容的法子
  • python
    执行shell命令并将结果保存的实例
  • shell命令行,一键创造 python
    模板文件脚本方法
  • 行使Python+Java调用Shell脚本时的死锁陷阱详解
  • 选取Python生成Shell命令,批量实践程序代码解析
  • python
    SSH模块登录,远程机执行shell命令实例分析
  • 用Python shell简化开发

Leave a Comment.