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利用MethodType绑定方法到类示例代码
Aug 27 Python
python中reduce()函数的使用方法示例
Sep 29 Python
Python3实现发送QQ邮件功能(附件)
Dec 23 Python
如何用python整理附件
May 13 Python
python实现windows壁纸定期更换功能
Jan 21 Python
解决python3中的requests解析中文页面出现乱码问题
Apr 19 Python
Python supervisor强大的进程管理工具的使用
Apr 24 Python
简单了解python的内存管理机制
Jul 08 Python
python实现简单井字棋游戏
Mar 04 Python
python开发实例之python使用Websocket库开发简单聊天工具实例详解(python+Websocket+JS)
Mar 18 Python
keras 两种训练模型方式详解fit和fit_generator(节省内存)
Jul 03 Python
python 装饰器的基本使用
Jan 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
Thinkphp多文件上传实现方法
2014/10/31 PHP
XHProf报告字段含义的解析
2016/05/17 PHP
PHP实现的分解质因数操作示例
2018/08/01 PHP
深入理解JavaScript 闭包究竟是什么
2013/04/12 Javascript
详解JavaScript异步编程中jQuery的promise对象的作用
2016/05/03 Javascript
基于BootStrap Metronic开发框架经验小结【三】下拉列表Select2插件的使用
2016/05/12 Javascript
Vue.js一个文件对应一个组件实践
2016/10/27 Javascript
jQuery使用siblings获取某元素所有同辈(兄弟姐妹)元素用法示例
2017/01/30 Javascript
AngularJS监听路由变化的方法
2017/03/07 Javascript
JS实现的二叉树算法完整实例
2017/04/06 Javascript
详解Vue2.x-directive的学习笔记
2017/07/17 Javascript
angular2组件中定时刷新并清除定时器的实例讲解
2018/08/31 Javascript
详解关于表格合并span-method方法的补充(表格数据由后台动态返回)
2019/05/21 Javascript
让 babel webpack vue 配置文件支持智能提示的方法
2019/06/22 Javascript
axios解决高并发的方法:axios.all()与axios.spread()的操作
2020/11/09 Javascript
Python编写检测数据库SA用户的方法
2014/07/11 Python
Ruby使用eventmachine为HTTP服务器添加文件下载功能
2016/04/20 Python
Python编程之变量赋值操作实例分析
2017/07/24 Python
Python基于numpy灵活定义神经网络结构的方法
2017/08/19 Python
Python入门之三角函数sin()函数实例详解
2017/11/08 Python
浅谈numpy库的常用基本操作方法
2018/01/09 Python
python增加图像对比度的方法
2019/07/12 Python
详解Python Qt的窗体开发的基本操作
2019/07/14 Python
Django框架安装方法图文详解
2019/11/04 Python
Python3 中作为一等对象的函数解析
2019/12/11 Python
python Qt5实现窗体跟踪鼠标移动
2019/12/13 Python
HTML5移动开发图片压缩上传功能
2016/11/09 HTML / CSS
基于HTML5的齿轮动画特效
2016/02/29 HTML / CSS
欧洲顶级的童装奢侈品购物网站:Bambini Fashion(面向全球)
2018/04/24 全球购物
请问软件开发中的设计模式你会使用哪些
2015/05/13 面试题
王力宏牛津大学演讲稿
2014/05/22 职场文书
公司员工活动策划方案
2014/08/20 职场文书
2014年度个人工作总结范文
2015/03/09 职场文书
2015年少先队活动总结
2015/03/25 职场文书
导游词之寿县报恩寺
2020/01/19 职场文书
使用Python的开发框架Brownie部署以太坊智能合约
2021/05/28 Python