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赋值操作方法分享
Mar 23 Python
Python抓取京东图书评论数据
Aug 31 Python
跟老齐学Python之深入变量和引用对象
Sep 24 Python
Python获取单个程序CPU使用情况趋势图
Mar 10 Python
Python类属性与实例属性用法分析
May 09 Python
Python减少循环层次和缩进的技巧分析
Mar 15 Python
python 调用c语言函数的方法
Sep 29 Python
Python对多属性的重复数据去重实例
Apr 18 Python
Django框架模板介绍
Jan 15 Python
python定时任务 sched模块用法实例
Nov 04 Python
python爬虫开发之Beautiful Soup模块从安装到详细使用方法与实例
Mar 09 Python
python解包用法详解
Feb 17 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之图片上传类实例代码(加了缩略图)
2016/06/30 PHP
PHP操作MySQL中BLOB字段的方法示例【存储文本与图片】
2017/09/15 PHP
javascript 表格排序和表头浮动效果(扩展SortTable)
2009/04/07 Javascript
bootstrap data与jquery .data
2014/07/07 Javascript
Jquery uploadify上传插件使用详解
2016/01/13 Javascript
jQuery实现的小图列表,大图展示效果幻灯片示例
2016/10/25 Javascript
AngularJS中的DOM操作用法分析
2016/11/04 Javascript
jquery操作select取值赋值与设置选中实例
2017/02/28 Javascript
jQuery中过滤器的基本用法示例
2017/10/11 jQuery
基于vue开发微信小程序mpvue-docs跳转页面功能
2019/04/10 Javascript
微信小程序实现授权登录
2019/05/15 Javascript
Vuex实现购物车小功能
2020/08/17 Javascript
Vue检测屏幕变化来改变不同的charts样式实例
2020/10/26 Javascript
python 容器总结整理
2017/04/04 Python
PySide和PyQt加载ui文件的两种方法
2019/02/27 Python
Python 中Django安装和使用教程详解
2019/07/03 Python
python内存管理机制原理详解
2019/08/12 Python
利用python实现周期财务统计可视化
2019/08/25 Python
python 实现提取log文件中的关键句子,并进行统计分析
2019/12/24 Python
Python telnet登陆功能实现代码
2020/04/16 Python
CSS3实现类似翻书效果的过渡动画的示例代码
2019/09/06 HTML / CSS
美国在线珠宝商店:SZUL
2017/02/11 全球购物
加拿大廉价机票预订网站:CheapOair.ca
2018/03/04 全球购物
小橄榄树:Le Petit Olivier
2018/04/23 全球购物
人力资源专员自我评价怎么写
2013/09/19 职场文书
进修护士自我鉴定
2013/10/14 职场文书
个人求职信范文分享
2014/01/31 职场文书
大学同学十年聚会感言
2014/02/21 职场文书
市政管理求职信范文
2014/05/07 职场文书
2014年个人业务工作总结
2014/11/17 职场文书
暑期社会实践证明书
2014/11/17 职场文书
《狼王梦》读后感:可怜天下父母心
2019/11/01 职场文书
有关信念的名言语录集锦
2019/12/06 职场文书
Nginx 过滤静态资源文件的访问日志的实现
2021/03/31 Servers
ORACLE查看当前账号的相关信息
2021/06/18 Oracle
从零开始在Centos7上部署SpringBoot项目
2022/04/07 Servers