Python中嵌入adb命令的方法

1.os.system('cmd')

os.system('cat /proc/cpuinfo')

直接执行参数中传入的命令,无法获取输出和返回值。

2.os.popen('cmd')

output=os.popen('cat /proc/cpuinfo')

print(output.read())

通过 os.popen() 返回的是 file read 的对象,对其进行读取 read() 的操作可以看到执行的输出。

3.commands.getstatusoutput('cmd')

(status,output)=commands.getstatusoutput('cat /proc/cpuinfo')

printstatus,output

一个方法就可以获得到返回值和输出。

PS:commands引用的时候需要加入import commands(可能不支持报No module named Commands)。

subprocess子模块

摘自:www.jb51.net/article/48086.htm

从Python 2.4开始,Python引入subprocess模块来管理子进程,以取代一些旧模块的方法:如 os.system、os.spawn*、os.popen*、popen2.*、commands.*不但可以调用外部的命令作为子进程,而且可以连接到子进程的input/output/error管道,获取相关的返回信息。

subprocess包中定义有数个创建子进程的函数,这些函数分别以不同的方式创建子进程,所以我们可以根据需要来从中选取一个使用。另外subprocess还提供了一些管理标准流(standard stream)和管道(pipe)的工具,从而在进程间使用文本通信。

1.subprocess.call()

父进程等待子进程完成,返回状态码0,否则抛异常

2.subprocess.check_call()

父进程等待子进程完成,返回0,否则抛异常

3.subprocess.check_output()

父进程等待子进程完成,返回子进程向标准输出的输出结果。

Python中嵌入adb命令的方法_第1张图片

4.subprocess.Popen()

与上面的几个函数不同,Popen对象创建后,主程序不会自动等待子进程完成。必须调用对象的wait()方法,父进程才会等待 (也就是阻塞block)。

参数      注释

argsshell                     命令,可以是字符串或者序列类型(如:list,元组)

bufsize                        指定缓冲。0 无缓冲,1 行缓冲,其他 缓冲区大小,负值 系统缓冲

stdin, stdout, stderr     分别表示程序的标准输入、输出、错误句柄

preexec_fn                  只在Unix平台下有效,用于指定一个可执行对象(callable object),它将在子进程运行之                                     前被调用

close_sfs                     在windows平台下,如果close_fds被设置为True,则新创建的子进程将不会继承父进程的                                     输入、输出、错误管道。所以不能将close_fds设置为True同时重定向子进程的标准输入、                                     输出与错误(stdin, stdout, stderr)。

shell                            同上

cwd                             用于设置子进程的当前目录

env                             用于指定子进程的环境变量。如果env = None,子进程的环境变量将从父进程中继承。

universal_newlines    不同系统的换行符不同,True -> 同意使用 \n

startupinfo                  只在windows下有效,将被传递给底层的CreateProcess()函数,用于设置子进程的一些属                                    性,如:主窗口的外观,进程的优先级等等

createionflags            同上


创建Popen对象:child=subprocess.Popen(...)

可以在父进程中对子进程进行其它操作,如child对象:

child.poll() # 检查子进程状态

child.kill() # 终止子进程

child.send_signal() # 向子进程发送信号

child.terminate() # 终止子进程

子进程的PID存储在child.pid

子进程的文本流控制

子进程的标准输入、标准输出和标准错误如下属性分别表示:

child.stdin

child.stdout

child.stderr

可以在Popen()建立子进程的时候改变标准输入、标准输出和标准错误,并可以利用subprocess.PIPE将多个子进程的输入和输出连接在一起,构成管道(pipe),如下2个例子:

>>> import subprocess

>>> child1 = subprocess.Popen(["ls","-l"], stdout=subprocess.PIPE)

>>> print child1.stdout.read(),

#或者child1.communicate()

>>> import subprocess

>>> child1 = subprocess.Popen(["cat","/etc/passwd"], stdout=subprocess.PIPE)

>>> child2 = subprocess.Popen(["grep","0:0"],stdin=child1.stdout, stdout=subprocess.PIPE)

>>> out = child2.communicate()

subprocess.PIPE实际上为文本流提供一个缓存区。child1的stdout将文本输出到缓存区,随后child2的stdin从该PIPE中将文本读取走。child2的输出文本也被存放在PIPE中,直到communicate()方法从PIPE中读取出PIPE中的文本。

你可能感兴趣的:(Python中嵌入adb命令的方法)