视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
监控python logcat关键字
2020-11-02 18:24:55 责编:小采
文档


相关学习推荐:python教程

本文主要介绍使用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("没有正在执行的任务
")
 else:
 STOP_LOGCAT = True
 print("正在停止关键字监控
")

监控关键字主函数,

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
" % (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"后输出如下,通过对命令执行拿到的字符串切割获取所有设备号以列表方式存储

# 获取所有device
def get_devices():
 command = "adb devices"
 res = os.popen(command).read()
 devices = []
 res = res.split("
")
 for i in res:
 if i.endswith("device"):
 devices.append(i.split('	')[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:开启关键字监控
2:停止关键字监控
3:退出")
 print("-" * 100)
 instruction = str(input("

请输入要进行的操作号:
"))
 print("-" * 100)
 while instruction not in INSTRUCTION.keys():
 instruction = str(input("

输入无效,请重新输入:"))
 if int(instruction) == 9:
 exit() # TODO 退出前需要判断是否有正在执行的monkey任务和关键字监控任务
 eval(INSTRUCTION[str(instruction)] + "()")


if __name__ == '__main__':
 main()

代码分段之后有点凌乱,看不明白可以把代码复制到一个文件里捋一下就明白了

想了解更多编程学习,敬请关注php培训栏目!

下载本文
显示全文
专题