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 THREADING模块中的JOIN()方法深入理解
Feb 18 Python
python实现给数组按片赋值的方法
Jul 28 Python
django rest framework 数据的查找、过滤、排序的示例
Jun 25 Python
tensorflow 用矩阵运算替换for循环 用tf.tile而不写for的方法
Jul 27 Python
Python实现FLV视频拼接功能
Jan 21 Python
python 制作python包,封装成可用模块教程
Jul 13 Python
python给视频添加背景音乐并改变音量的具体方法
Jul 19 Python
python 实现简单的计算器(gui界面)
Nov 11 Python
python 基于opencv 绘制图像轮廓
Dec 11 Python
10个python爬虫入门基础代码实例 + 1个简单的python爬虫完整实例
Dec 16 Python
python 下载文件的几种方式分享
Apr 07 Python
python实现简单区块链结构
Apr 25 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简单提示框alert封装函数
2010/08/08 PHP
PHP快速按行读取CSV大文件的封装类分享(也适用于其它超大文本文件)
2014/04/10 PHP
ThinkPHP CURD方法之data方法详解
2014/06/18 PHP
smarty模板引擎使用内建函数foreach循环取出所有数组值的方法
2015/01/22 PHP
php集成套件服务器xampp安装使用教程(适合第一次玩PHP的新手)
2015/06/03 PHP
thinkphp在低版本Nginx 下支持PATHINFO的方法分享
2016/05/27 PHP
PHP全局使用Laravel辅助函数dd
2019/12/26 PHP
Javascript小技巧之生成html元素
2014/05/15 Javascript
jquery中ajax使用error调试错误的方法
2015/02/08 Javascript
JS实现浏览器状态栏文字闪烁效果的方法
2015/10/27 Javascript
js与jquery分别实现tab标签页功能的方法
2016/11/18 Javascript
vee-validate vue 2.0自定义表单验证的实例
2018/08/28 Javascript
layer.open弹层查看缩略图的原图,自适应大小的实例
2019/09/05 Javascript
JS实现按比例缩小图片宽高
2020/08/24 Javascript
用于统计项目中代码总行数的Python脚本分享
2015/04/21 Python
为Python的web框架编写MVC配置来使其运行的教程
2015/04/30 Python
用python实现将数组元素按从小到大的顺序排列方法
2018/07/02 Python
Python3.5面向对象编程图文与实例详解
2019/04/24 Python
浅谈python新式类和旧式类区别
2019/04/26 Python
廉价连衣裙和婚纱礼服在线销售:Tbdress
2019/02/28 全球购物
超级英雄、电影和电视、乐队和音乐T恤:Loud Clothing
2019/09/01 全球购物
PHP面试题大全
2015/10/16 面试题
学生实习推荐信范文
2013/11/26 职场文书
财务部经理岗位职责
2014/02/03 职场文书
酒店管理专业自荐信
2014/05/23 职场文书
大学迎新标语
2014/06/26 职场文书
销售员未完成销售业绩的检讨书
2014/10/12 职场文书
党的群众路线专项整治方案
2014/11/03 职场文书
师德标兵先进事迹材料
2014/12/19 职场文书
北京故宫导游词
2015/01/31 职场文书
单位政审意见范文
2015/06/04 职场文书
2015小学师德工作总结
2015/07/21 职场文书
房地产置业顾问工作总结
2015/10/23 职场文书
Redis 配置文件重要属性的具体使用
2021/05/20 Redis
Django + Taro 前后端分离项目实现企业微信登录功能
2022/04/07 Python
我国拿下天问一号火星着陆区附近 22 个地理实体命名:平乐、西柏坡、古田、漠河等
2022/04/29 数码科技