python 监控logcat关键字功能


Posted in Python onSeptember 04, 2020

本文主要介绍使用Python调用ADB命令实现实时监控logcat关键字的功能

采用多进程,可同时监控多个设备,监控多个关键字。

需要配置ADB环境,具体配置就不多介绍,随便搜一下一大把,直接上代码

通过一个全局变量控制开启和关闭监控功能, INSTRUCTION 用于根据指令获取对应的方法名

import os, threading, datetime
 
# 获取当前文件所在目录,拼接出LOG路径
LOG_PATH = os.path.join(os.path.dirname(os.path.abspath(__file__)), "log")
 
# 配置需要监控的关键字
KEYWORDS = ["ANR ", "NullPointerException", "CRASH", "Force Closed"]
 
# 控制开启和关闭
STOP_LOGCAT = True
 
# 指令对应具体操作
INSTRUCTION = {
    "1": "filter_keywords",
    "2": "stop_filter_keywords",
    "3": "exit"
    }
 
def filter_keywords():
 global STOP_LOGCAT
 STOP_LOGCAT = False
 devices = get_devices() # 先获取所有连接的设备
 print("开始监控关键字")
 for device in devices:
  t = threading.Thread(target=filter_keyword, args=(device,))
  t.start()
 
def stop_filter_keywords():
 global STOP_LOGCAT
 if STOP_LOGCAT:
  print("没有正在执行的任务\n")
 else:
  STOP_LOGCAT = True
  print("正在停止关键字监控\n")

监控关键字主函数,

def filter_keyword(device):
 print("设备%s关键字监控已开启" % str(device))
 sub = logcat(device)
 with sub:
  for line in sub.stdout: # 子进程会持续输出日志,对子进程对象.stdout进行循环读取
   for key in KEYWORDS:
    if line.decode("utf-8").find(key) != -1: # stdout输出为字节类型,需要转码
     message = "设备:%s 检测到:%s\n" % (device, key)# 设备:192.168.56.104:5555 检测到:ANR
     path = get_log_path("bugreport") # 根据时间创建文件夹
     bugreport(device, path)# 拉取完整日志压缩包到创建的文件夹内
     send_message(message) # 这里可以换成自己要做的事情,比如发送邮件或钉钉通知
   if STOP_LOGCAT:
    break
  print("设备%s关键字监控已停止" % str(device))
  sub.kill()

通过 subprocess.Popen 创建进程执行命令,持续输出日志到 stdout

# logcat持续输出日志
def logcat(device):
 command = "adb -s " + str(device) + " logcat -v time"
 sub = subprocess.Popen(command, shell=True, stdout=subprocess.PIPE, stderr=subprocess.PIPE)
 return sub

获取所有已连接设备的方法,执行"adb devices"后输出如下,通过对命令执行拿到的字符串切割获取所有设备号以列表方式存储

python 监控logcat关键字功能

# 获取所有device
def get_devices():
 command = "adb devices"
 res = os.popen(command).read()
 devices = []
 res = res.split("\n")
 for i in res:
  if i.endswith("device"):
   devices.append(i.split('\t')[0])
 return devices
# 打包下载所有日志到当前目录
def bugreport(device, path):
 os.chdir(path)# bugreport会下载日志到当前文件夹,所以需要先切换到已经创建的目录
 command = "adb -s " + str(device) + " bugreport"
 subprocess.Popen(command, shell=True, stdout=subprocess.PIPE, stderr=subprocess.PIPE, bufsize=-1)
 print("设备:%s 日志路径:%s" % (str(device), path))

以  当前文件所在目录/年/月/日 格式获取日志路径,如果不存在自动创建

# 获取日志存放路径,如果不存在则按日期创建
def get_log_path(tag):
 year = datetime.datetime.now().strftime('%Y')
 month = datetime.datetime.now().strftime('%m')
 day = datetime.datetime.now().strftime('%d')
 path = os.path.join(LOG_PATH, tag, year, month, day)
 if not os.path.exists(path):
  os.makedirs(path)
 return path

main函数,循环接收指令,根据接收的指令拿到方法名,并通过eval()方法执行。

def main():
 while True:
  print("-" * 100)
  print("1:开启关键字监控\n2:停止关键字监控\n3:退出")
  print("-" * 100)
  instruction = str(input("\n\n请输入要进行的操作号:\n"))
  print("-" * 100)
  while instruction not in INSTRUCTION.keys():
   instruction = str(input("\n\n输入无效,请重新输入:"))
  if int(instruction) == 9:
   exit() # TODO 退出前需要判断是否有正在执行的monkey任务和关键字监控任务
  eval(INSTRUCTION[str(instruction)] + "()")
 
if __name__ == '__main__':
 main()

这里只写了开启日志监控和关闭的方法,中间有些处理可以根据自己需要实现,比如检测到关键字之后除了拉取所有日志外,可以发送邮件、钉钉之类的通知,根据自己需要去实现。

总结

到此这篇关于python 监控logcat关键字功能的文章就介绍到这了,更多相关python 监控logcat关键字内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Python 相关文章推荐
Python-基础-入门 简介
Aug 09 Python
Python实现的Google IP 可用性检测脚本
Apr 23 Python
在Django的模板中使用认证数据的方法
Jul 23 Python
Python语法快速入门指南
Oct 12 Python
解决python2.7用pip安装包时出现错误的问题
Jan 23 Python
Python Pandas数据结构简单介绍
Jul 03 Python
Python unittest单元测试框架实现参数化
Apr 29 Python
在echarts中图例legend和坐标系grid实现左右布局实例
May 16 Python
python pymysql链接数据库查询结果转为Dataframe实例
Jun 05 Python
哪种Python框架适合你?简单介绍几种主流Python框架
Aug 04 Python
Python如何批量生成和调用变量
Nov 21 Python
pytorch加载预训练模型与自己模型不匹配的解决方案
May 13 Python
如何将json数据转换为python数据
Sep 04 #Python
利用python3筛选excel中特定的行(行值满足某个条件/行值属于某个集合)
Sep 04 #Python
Python读取Excel一列并计算所有对象出现次数的方法
Sep 04 #Python
学习Python需要哪些工具
Sep 04 #Python
详解python tkinter包获取本地绝对路径(以获取图片并展示)
Sep 04 #Python
Python程序慢的重要原因
Sep 04 #Python
利用Python实现朋友圈中的九宫格图片效果
Sep 03 #Python
You might like
中国的第一台收音机
2021/03/01 无线电
PHP 编程安全性小结
2010/01/08 PHP
php_pdo 预处理语句详解
2016/11/21 PHP
PHP中递归的实现实例详解
2017/11/14 PHP
laravel实现按时间日期进行分组统计方法示例
2019/03/23 PHP
jQuery技巧大放送 学习jquery的朋友可以看下
2009/10/14 Javascript
jQuery 点击图片跳转上一张或下一张功能的实现代码
2010/03/12 Javascript
基于jQuery的输入框在光标位置插入内容, 并选中
2011/10/29 Javascript
javascript 事件处理、鼠标拖动效果实现方法详解
2012/05/11 Javascript
THREE.JS入门教程(6)创建自己的全景图实现步骤
2013/01/25 Javascript
jquery实现带复选框的表格行选中删除时高亮显示
2013/08/01 Javascript
移动节点的jquery代码
2014/01/13 Javascript
js常用自定义公共函数汇总
2014/01/15 Javascript
jquery对元素拖动排序示例
2014/01/16 Javascript
jQuery的选择器中的通配符使用介绍
2014/03/20 Javascript
JS实现的简洁二级导航菜单雏形效果
2015/10/13 Javascript
HTML Table 空白单元格补全的简单实现
2016/10/13 Javascript
jQuery插件DataTable使用方法详解(.Net平台)
2016/12/22 Javascript
详解nodejs 文本操作模块-fs模块(五)
2016/12/23 NodeJs
vue2.0中goods选购栏滚动算法的实现代码
2017/05/17 Javascript
angularjs数组判断是否含有某个元素的实例
2018/02/27 Javascript
JS实现的获取银行卡号归属地及银行卡类型操作示例
2019/01/08 Javascript
[55:02]2014 DOTA2国际邀请赛中国区预选赛 HGT VS Orenda
2014/05/21 DOTA
[00:32]2018DOTA2亚洲邀请赛iG出场
2018/04/03 DOTA
Python 命令行非阻塞输入的小例子
2013/09/27 Python
python正则分组的应用
2013/11/10 Python
Python原始字符串(raw strings)用法实例
2014/10/13 Python
Python中线程的MQ消息队列实现以及消息队列的优点解析
2016/06/29 Python
Django中如何防范CSRF跨站点请求伪造攻击的实现
2019/04/28 Python
python matplotlib折线图样式实现过程
2019/11/04 Python
python如何用matplotlib创建三维图表
2021/01/26 Python
沃达丰英国有限公司:Vodafone英国
2019/04/16 全球购物
高二学生评语大全
2014/04/25 职场文书
英文道歉信
2015/01/20 职场文书
小学少先队活动总结
2015/05/08 职场文书
2016创先争优活动党员公开承诺书
2016/03/24 职场文书