美文网首页
2018-10-18adb logcat subprocess

2018-10-18adb logcat subprocess

作者: 夏树的宝马 | 来源:发表于2018-12-08 14:10 被阅读13次
    先举一个Android查询连接设备的命令来看看Python中subprocess.Popen怎么样的写法。用到的命令为 adb devices。
    
      import subprocess
    
      order='adb devices' #获取连接设备
    
      pi= subprocess.Popen(order,shell=True,stdout=subprocess.PIPE)
    
      print pi.stdout.read()#打印结果
    
    
    
    命令的结果返回是一次性的,
    所以我们用read方法读取数据是没有问题的,
    然而adb命令里还有一些实时返回结果的,
    比如输出手机日志的命令logcat,
    结果会不断的打印出来当前的设备操作日志信息内容,
    这种类型的命令我们在Python中如果需要获取打印结果,
    如果还是用read方法的话,等待结果的返回时间会非常长,
    这里我们就要换一种方法读取结果,写法如下。
    
      import subprocess
    
      order='adb logcat'
    
      pi= subprocess.Popen(order,shell=True,stdout=subprocess.PIPE)
    
      for i in iter(pi.stdout.readline,'b'):
    
          print i
    
    
    
    这样的打印效果,如同cmd里操作一致,实时的打印出日志信息。这里我们就用到了readline方法和iter()函数,其实这种写法类似我们读取文件,单行读取和全部内容读取。
    

    http://blog.sina.com.cn/s/blog_44d19b500102x21i.html
    https://www.jianshu.com/p/8e582146bd4c

    相关文章

      网友评论

          本文标题:2018-10-18adb logcat subprocess

          本文链接:https://www.haomeiwen.com/subject/bfyszftx.html