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排序方法实例分析
Apr 30 Python
python和bash统计CPU利用率的方法
Jul 10 Python
python+selenium实现京东自动登录及秒杀功能
Nov 18 Python
Python生成器generator用法示例
Aug 10 Python
python flask安装和命令详解
Apr 02 Python
python基于itchat模块实现微信防撤回
Apr 29 Python
对pyqt5之menu和action的使用详解
Jun 20 Python
jupyter notebook 使用过程中python莫名崩溃的原因及解决方式
Apr 10 Python
如何使用Python自动生成报表并以邮件发送
Oct 15 Python
在终端启动Python时报错的解决方案
Nov 20 Python
Pandas DataFrame求差集的示例代码
Dec 13 Python
TensorFlow的环境配置与安装方法
Feb 20 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 读取文件内容代码(txt,js等)
2009/12/06 PHP
谷歌音乐搜索栏的提示功能php修正代码
2011/05/09 PHP
Thinkphp中volist标签mod控制一定记录的换行BUG解决方法
2014/11/04 PHP
PHP 正则表达式小结
2015/02/12 PHP
PHP基于DOMDocument解析和生成xml的方法分析
2017/07/17 PHP
jquery tools之tabs 选项卡/页签
2009/07/25 Javascript
js左侧多级菜单动态的解决方案
2010/02/01 Javascript
返回页面顶部top按钮通过锚点实现(自写)
2013/08/30 Javascript
使用js判断当前时区TimeZone是否是夏令时
2014/02/23 Javascript
JS使用for循环遍历Table的所有单元格内容
2014/08/21 Javascript
JavaScript学习笔记之取数组中最大值和最小值
2016/03/23 Javascript
jQuery响应滚动条事件功能示例
2017/10/14 jQuery
js 中rewrap-ajax.js插件实例代码
2017/10/20 Javascript
基于Vue2.0+ElementUI实现表格翻页功能
2017/10/23 Javascript
vue从一个页面跳转到另一个页面并携带参数的解决方法
2019/08/12 Javascript
微信小程序8种数据通信的方式小结
2020/02/03 Javascript
通过实例解析vuejs如何实现调试代码
2020/07/16 Javascript
vue打包静态资源后显示空白及static文件路径报错的解决
2020/09/02 Javascript
pyqt4教程之实现半透明的天气预报界面示例
2014/03/02 Python
Python脚本实现格式化css文件
2015/04/08 Python
python中range()与xrange()用法分析
2016/09/21 Python
python爬虫_实现校园网自动重连脚本的教程
2018/04/22 Python
用Python PIL实现几个简单的图片特效
2019/01/18 Python
Python函数参数匹配模型通用规则keyword-only参数详解
2019/06/10 Python
Python3 实现串口两进程同时读写
2019/06/12 Python
CSS3教程(6):创建网站多列
2009/04/02 HTML / CSS
CSS3 filter(滤镜)实现网页灰色或者黑色模式的示例代码
2021/02/24 HTML / CSS
在校生党员自我评价
2013/09/25 职场文书
服务质量承诺书
2014/03/27 职场文书
汽车维修专业自荐书
2014/05/26 职场文书
中国合伙人观后感
2015/06/02 职场文书
实用求职信模板范文
2019/05/13 职场文书
vue整合百度地图显示指定地点信息
2022/04/06 Vue.js
Tomcat执行startup.bat出现闪退的原因及解决办法
2022/04/20 Servers
Django框架之路由用法
2022/06/10 Python
Java异常体系非正常停止和分类
2022/06/14 Java/Android