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程序代码片段
Jun 02 Python
详解python3百度指数抓取实例
Dec 12 Python
Python装饰器(decorator)定义与用法详解
Feb 09 Python
tensorflow实现KNN识别MNIST
Mar 12 Python
基于python 二维数组及画图的实例详解
Apr 03 Python
Python动态导入模块的方法实例分析
Jun 28 Python
django页面跳转问题及注意事项
Jul 18 Python
django自定义模板标签过程解析
Dec 14 Python
浅谈matplotlib.pyplot与axes的关系
Mar 06 Python
Python3 filecmp模块测试比较文件原理解析
Mar 23 Python
Python中json.load()和json.loads()有哪些区别
Jun 07 Python
Python-OpenCV教程之图像的位运算详解
Jun 21 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
PHP将DateTime对象转化为友好时间显示的实现代码
2011/09/20 PHP
php获取文件类型和文件信息的方法
2015/07/10 PHP
php实现上传图片文件代码
2015/07/19 PHP
PHP防盗链的基本思想 防盗链的设置方法
2015/09/25 PHP
基于jQuery的遍历同id元素 并响应事件的代码
2012/06/14 Javascript
js indexOf()定义和用法
2012/10/21 Javascript
jquery等待效果示例
2014/05/01 Javascript
jquery 取子节点及当前节点属性值
2014/07/25 Javascript
常用的jquery模板插件——jQuery Boilerplate介绍
2014/09/23 Javascript
js父页面与子页面不同时显示的方法
2014/10/16 Javascript
Javascript 完美运动框架(逐行分析代码,让你轻松了运动的原理)
2015/01/23 Javascript
深入理解JavaScript系列(48):对象创建模式(下篇)
2015/03/04 Javascript
js+css绘制颜色动态变化的圈中圈效果
2016/01/27 Javascript
jQuery简单自定义图片轮播插件及用法示例
2016/11/21 Javascript
Javascript循环删除数组中元素的几种方法示例
2017/05/18 Javascript
Mongoose实现虚拟字段查询的方法详解
2017/08/15 Javascript
JS实现留言板功能[楼层效果展示]
2017/12/27 Javascript
vue.js做一个简单的编辑菜谱功能
2018/05/08 Javascript
JavaScript之实现一个简单的Vue示例
2019/01/17 Javascript
react PropTypes校验传递的值操作示例
2020/04/28 Javascript
Vue循环中多个input绑定指定v-model实例
2020/08/31 Javascript
[01:33]真香警告!DOTA2勇士令状不朽珍藏Ⅱ饰品欣赏
2018/06/26 DOTA
详解JavaScript编程中的window与window.screen对象
2015/10/26 Python
windows下python安装paramiko模块和pycrypto模块(简单三步)
2017/07/06 Python
Pytorch中accuracy和loss的计算知识点总结
2019/09/10 Python
捷克原创男装和女装购物网站:Bolf.cz
2018/04/28 全球购物
网络事业创业计划书范文
2014/01/09 职场文书
护士长竞聘书
2014/03/31 职场文书
服装设计专业毕业生求职信
2014/04/09 职场文书
《金色的脚印》教后反思
2014/04/23 职场文书
财政局党的群众路线教育实践活动剖析材料
2014/10/13 职场文书
2014年超市员工工作总结
2014/11/18 职场文书
投标承诺函范文
2015/01/21 职场文书
新生儿未入户证明
2015/06/23 职场文书
外出考察学习心得体会
2016/01/18 职场文书
干货:企业内部人才推荐奖励方案!
2019/07/09 职场文书