接上一篇:adb命令_一键截取logcat日志

有一天, 系统稳定性开发负责人找到我,希望我能在跑android 系统monkey的时候,

实时监控logcat的输出,如果一旦发现“java.lang.NullPointerException"空指针异常,

则立刻用adb bugreport命令导出当时log压缩包出来。

准备阶段
  1. adb logcat -v threadtime > D:\logcat_20200310_101112.txt可以打印按线程时间log并保存到一个文件。
  2. 由于adb logcat命令是一个持续输出的命令,它如果没被销毁(杀进程),会一直持续截取下去。
  3. subprocess.Popen()类是支持通过stdout=subprocess.PIPE来持续获取输出的并按行读取。
  4. adb bugreport只是一个命令,可以打包当时的tombstone, getprop, proc,cache等信息。
Python批处理脚本形式
# coding=utf-8

import os
import re
import subprocess command = "adb logcat -v threadtime" # 具体命令
keyword_reg = r".*java.lang.NullPointerException.*" # 正则表达式 # 开始执行adb命令
p_obj = subprocess.Popen(
args=command,
stdin=None, stdout=subprocess.PIPE,
stderr=subprocess.PIPE, shell=False) # 实时监控并过滤每一行生成的日志里的关键字
print("Logcat catching and filtering...")
with p_obj:
for line in p_obj.stdout:
if re.match(keyword_reg, line.decode("utf-8")):
print("Found %s" % keyword_reg)
print("running adb bugreport to pull releated logs...pls wait")
os.system("adb bugreport") # 导出一次bugreport log压缩包 os.system("pause")

re模块的匹配,查找,替换等各种操作,都只能对字符串操作。

p_obj.stdout输出的是bytes,所以需要进行utf-8解码后才能变成字符串。

Python面向过程函数形式
# coding=utf-8

import os
import re
import subprocess command = "adb logcat -v threadtime" # 具体命令
keyword_reg = r".*java.lang.NullPointerException.*" # 正则表达式 def filter_logcat():
# 开始执行adb命令
p_obj = subprocess.Popen(
args=command,
stdin=None, stdout=subprocess.PIPE,
stderr=subprocess.PIPE, shell=False) # 实时监控并过滤每一行生成的日志里的关键字
print("Logcat catching and filtering...")
with p_obj:
for line in p_obj.stdout:
if re.match(keyword_reg, line.decode("utf-8")):
print("Found %s" % keyword_reg)
print("running adb bugreport to pull releated logs...pls wait")
os.system("adb bugreport") # 导出一次bugreport log压缩包 filter_logcat()
os.system("pause")
Python面向对象形式
# coding=utf-8

import os
import re
import subprocess command = "adb logcat -v threadtime" # 具体命令
keyword_reg = r".*java.lang.NullPointerException.*" # 正则表达式 class LogcatFilter(object):
def __init__(self):
# 开始执行adb命令
self.p_obj = subprocess.Popen(
args=command, stdout=subprocess.PIPE,
stderr=subprocess.PIPE) def filter_logcat(self):
# 实时监控并过滤每一行生成的日志里的关键字
print("Logcat catching and filtering...")
with self.p_obj:
for line in self.p_obj.stdout:
if re.match(keyword_reg, line.decode("utf-8")):
print("Found %s" % keyword_reg)
print("running adb bugreport to pull releated logs...pls wait")
os.system("adb bugreport") # 导出一次bugreport log压缩包 if __name__ == '__main__':
l_obj = LogcatFilter()
l_obj.filter_logcat()
os.system("pause")
代码运行方式及效果

确保Android车机设备通过USB线与电脑连接了,adb设备有效连接,

以上代码的3种实现形式都可以直接运行,比如保存为filter_logcat.py并放在桌面,

建议python filter_logcat.py运行,当然也可以双击运行, 效果如下:

更多更好的原创文章,请访问官方网站:www.zipython.com

自拍教程(自动化测试Python教程,武散人编著)

原文链接:https://www.zipython.com/#/detail?id=389e4bab6097442a8e72e063a0eafa97

也可关注“武散人”微信订阅号,随时接受文章推送。

《自拍教程45》Python_adb实时监控Logcat日志的更多相关文章

  1. 安装 log.io 实时监控 php_error 日志

    Log.io 实时监控 php_error.log 日志 开启 php_error 实时监控日志的第一步,要首先开启 php_error 的功能. vi php.ini 修改 PHP 配置文件,将 ; ...

  2. Nginx系列4:用GoAccess实现可视化并实时监控access日志

    1.ubuntu16.04安装GoAccess GoAccess下载地址:https://goaccess.io/download 安装步骤: $ wget https://tar.goaccess. ...

  3. nagios+logstash实时监控java日志(一)

    https://blog.csdn.net/yanggd1987/article/details/64121459

  4. 用goaccess实现可视化并实时监控access日志

    goaccess access.log -o ../html/report.html --real-time-html time-format='%H:%M:%S' --date-format=‘%d ...

  5. 一个小工具帮你搞定实时监控Nginx服务器

    Linux运维工程师的首要职责就是保证业务7 x 24小时稳定的运行,监控Web服务器对于查看网站上发生的情况至关重要.关注最多的便是日志变动,查看实时日志文件变动大家第一反应应该是'tail -f ...

  6. flume学习以及ganglia(若是要监控hive日志,hive存放在/tmp/hadoop/hive.log里,只要运行过hive就会有)

    python3.6hdfs的使用 https://blog.csdn.net/qq_29863961/article/details/80291654 https://pypi.org/  官网直接搜 ...

  7. 《自拍教程46》Python_adb自动拍照100张

    Android手机测试, 涉及照相机(Camera)应用程序的稳定性测试的用例, 需要涉及100张照片的拍照自动化测试. 准备阶段 先清理老照片,照片一般存放在/scard/DCIM目录下 adb s ...

  8. 《自拍教程51》Python_adb批量生成App版本表格

    案例一:版本在软件研发阶段是很重要的, 不同的版本, 已修复的Bug也不一样, 所实现的功能不一样, Android终端产品正式版本发布前,项目经理除了确保系统版本确定无误外, 还会逐个验证所搭载的所 ...

  9. 《自拍教程52》Python_adb运行Shell脚本

    Android作为一款Linux终端,肯定是支持.sh后缀的Shell脚本的运行的, 有时候测试环境准备或者长时间截取复杂的日志等,开发会给到一些Shell脚本. Shell脚本的执行的优势: 快捷高 ...

随机推荐

  1. h-index|IF|Good story|IPS

    科研论文写作 科研论文写作的关键在于写出研究的重要性. 对科研工作者的评价标准主要以论文为主,可以从论文的定性和定量角度评价.论文的外部评价,包括科学院分区(包括123类):影响因子IF,可以通过we ...

  2. MAYA卸载/完美解决安装失败/如何彻底卸载清除干净MAYA各种残留注册表和文件的方法

    在卸载MAYA重装MAYA时发现安装失败,提示是已安装或安装失败.这是因为上一次卸载后没有清理干净,系统会误认为已经安装过了.有的同学是新装的系统也会出现安装失败的情况,这是因为C++ 或者.NET的 ...

  3. Linux Ubuntu 安装SSH服务

    1.安装SSH命令:sudo apt-get install openssh-server 2.启动SSH服务命令:/etc/init.d/ssh start 3.停止SSH服务命令:/etc/ini ...

  4. VRRP笔记二:配置keepalived为实现haproxy高可用的配置文件示例

    ! Configuration File for keepalived global_defs { notification_email { linuxedu@foxmail.com mageedu@ ...

  5. 关于log4j中log4j.properties和log4j.xml的加载顺序

    如果采用log4j输出日志,要对log4j加载配置文件的过程有所了解. log4j启动时,默认会寻找source folder下的log4j.xml配置文件,若没有,会寻找log4j.properti ...

  6. javaweb 中 error-page

    我们的请求找不到时,会跳到错误页面,tomcat提供了一个错误页面,但是不太好.分析:tomcat自带错误页面不好的原因:有一下两点: 1.不好看: 2.不能为seo做出贡献.思考:如何解决以上问题? ...

  7. 用手机应用追踪城市噪声污染——微软Azure助力解决城市问题

    噪声无孔不入的城市地带(图片来自于网络) 2014年4月19日发行的<经济学人>杂志预言,到2030年,中国人口的70%(约10亿人)会在城市中居住.中国城镇化的高速发展一方面大大提高了 ...

  8. 1——PHP常见的系统常量

    */ * Copyright (c) 2016,烟台大学计算机与控制工程学院 * All rights reserved. * 文件名:text.cpp * 作者:常轩 * 微信公众号:Worldhe ...

  9. golang 统计系统测试覆盖率

    golang 统计系统测试覆盖率 参考资料 https://www.elastic.co/blog/code-coverage-for-your-golang-system-tests https:/ ...

  10. 分割文件和数据(linux)

    在某些情况下,必须把文件分割成多个更小的片段.如今我们分割文件的目的比如:提高可读性.生成日志.通过Email发送文件等等. 假设我们有一个erro.log的测试文件,其大小为14M.你可以将该文件分 ...