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实现进程间通信简单实例
Jul 23 Python
Python list操作用法总结
Nov 10 Python
探究python中open函数的使用
Mar 01 Python
Scrapy基于selenium结合爬取淘宝的实例讲解
Jun 13 Python
python计算阶乘和的方法(1!+2!+3!+...+n!)
Feb 01 Python
Python面向对象思想与应用入门教程【类与对象】
Apr 12 Python
python里dict变成list实例方法
Jun 26 Python
Python如何使用函数做字典的值
Nov 30 Python
Python关于反射的实例代码分享
Feb 20 Python
python使用pandas抽样训练数据中某个类别实例
Feb 28 Python
Python字典实现伪切片功能
Oct 28 Python
python manim实现排序算法动画示例
Aug 14 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
乐信RP2100的电路分析和打磨
2021/03/02 无线电
十天学会php之第七天
2006/10/09 PHP
PHP开发入门教程之面向对象
2006/12/05 PHP
laravel5.4生成验证码的实例讲解
2017/08/05 PHP
Laravel 之url参数,获取路由参数的例子
2019/10/21 PHP
javascript据option的value值快速设定初始的selected选项
2007/08/13 Javascript
关于javascript 回调函数中变量作用域的讨论
2009/09/11 Javascript
jquery预加载图片的方法
2015/05/27 Javascript
在for循环中length值是否需要缓存
2015/07/27 Javascript
Node.js编写爬虫的基本思路及抓取百度图片的实例分享
2016/03/12 Javascript
关于vue.js弹窗组件的知识点总结
2016/09/11 Javascript
JavaScript数据结构之单链表和循环链表
2017/11/28 Javascript
vue实现树形菜单效果
2018/03/19 Javascript
浅谈webpack+react多页面开发终极架构
2018/11/11 Javascript
简述pm2常用命令集合及配置文件说明
2019/05/30 Javascript
python定时采集摄像头图像上传ftp服务器功能实现
2013/12/23 Python
python列表操作之extend和append的区别实例分析
2015/07/28 Python
基于python脚本实现软件的注册功能(机器码+注册码机制)
2016/10/09 Python
详解python发送各类邮件的主要方法
2016/12/22 Python
python实现报表自动化详解
2017/11/16 Python
Python 机器学习库 NumPy入门教程
2018/04/19 Python
python如何求解两数的最大公约数
2018/09/27 Python
python 利用pyttsx3文字转语音过程详解
2019/09/25 Python
如何将你的应用迁移到Python3的三个步骤
2019/12/22 Python
ubuntu 安装pyqt5和卸载pyQt5的方法
2020/03/24 Python
Pycharm生成可执行文件.exe的实现方法
2020/06/02 Python
pytorch __init__、forward与__call__的用法小结
2021/02/27 Python
HTML实现代码雨源码及效果示例
2020/02/25 HTML / CSS
Baby Tulai澳大利亚:美国婴儿背带品牌
2018/10/15 全球购物
优秀员工年终发言演讲稿
2014/01/01 职场文书
婚庆司仪主持词
2014/03/15 职场文书
解除劳动合同协议书范本
2014/09/13 职场文书
征用土地赔偿协议书
2014/09/26 职场文书
学校师德师风自我剖析材料
2014/09/29 职场文书
委托收款证明
2015/06/23 职场文书
《只有一个地球》教学反思
2016/02/16 职场文书