python调用系统命令的方法

来源:互联网 发布:数据库概论第五版答案 编辑:程序博客网 时间:2024/06/05 04:52

我写的备份文件的程序里,通过os模块的system()方法调用了系统的rar.exe命令,这个方法会返回一个变量exit_status。

     # 用winrar的rar命令压缩文件       zip_command = "rar a %s %s" %(target_dir + target_file, source)         # 执行压缩打包命令       if os.system(zip_command)==0:           print('备份成功')       else:           print('备份失败') 

那个程序还调用了wmic命令,并且在wmic命令的结果里查找字符串,这时候用的是os模块的popen()方法,这个方法返回一个pipe对象,允许read或者write(但不允许同时读和写)。

    # 确认PATH变量里是否有winrar目录      path_value = os.popen('wmic ENVIRONMENT where "name=\'path\'" get VariableValue /value')      have_rar = path_value.read().find('WinRAR')      if have_rar == '-1':          print '请在系统PATH变量里设置WinRAR的路径'          sys.exit()  
如果需要同时读写一个管道,可以用popen2(),这篇文档解释了popen()和popen2()的区别:http://linhs.blog.51cto.com/370259/126831

注:subprocess的Popen()方法就于替换os模块的popen()、popen2()、popen3()、popen4()等方法。官方文件的说明在这里:http://docs.python.org/library/subprocess.html#replacing-older-functions-with-the-subprocess-module


备份数据库的程序里,用到了另一个方法,就是使用subprocess模块的call()方法来执行系统命令:

        # 调用sqlcmd命令备份数据库          # os.system()不能正常执行backup_db_cmd命令,因为它没有正常处理sql_cmd里的空格。          subprocess.call(backup_db_cmd) 

os.system("d:\tools\test.exe")没有问题,但是os.system("D:\\Program Files\\Microsoft SQL Server\\90\\Tools\\Binn\\sqlcmd.exe")的时候就执行失败了,因为参数里含有空格,system()不能正常执行,这里的解决的方法是用subprocess.call()替换os.system()。
subprocess.call()本来就是用来代替os.system()的。






原创粉丝点击