python 分析android日志获取activit加载时间

本文详细介绍了如何通过Android日志分析提取特定应用版本更新前后单个activity加载时间的变化,包括日志文件的读取、解析以及时间单位的转换等关键步骤。通过Python代码实现,帮助开发者快速定位性能瓶颈。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最近有个需求,需要对比前后两个版本单个activity加载的时间

在android日志中我们可以看到类似INFO/ActivityManager(2486): Displayed activity com.teleca/.ContextMenuActivity: 240 ms (total 41289 ms)的日志,即为Activity的加载时间

首先通过adb logcat > xx.txt获取日志,然后用如下代码分析日志:

#-*-coding:utf-8 -*-

# 分析android adb logcat日志 提取activity Displayed日志

import os
import re


def AndroidDisplayedLog(applicationName, logfile):
    if os.path.exists(logfile):
        with open(logfile) as f:
            log = f.readlines()
        ActivityLoadTime = []
        for line in log:
            if re.search(r"Displayed %s" % applicationName, line):
                ActivityManagerLog = line.split(":")
                activity = ActivityManagerLog[1].split("/")[-1]
                loadTimeStr = ActivityManagerLog[-1].strip().strip('ms').strip('+')
                # 日志时间转换为ms的整数
                try:
                    t = int(loadTimeStr)
                    if t:
                        loadtime = t
                except ValueError:
                    # 过滤常驻的系统activity 超过分钟的
                    try:
                        loadtime = int(loadTimeStr.split('s')[0]) * 1000 + int(loadTimeStr.split('s')[1])
                    except ValueError:
                        pass
                print activity, loadtime
                ActivityLoadTime.append((activity, loadtime))
        return ActivityLoadTime
    else:
        print "日志文件不存在"

a = AndroidDisplayedLog("com.aaa.bbbb", "D:\\log.txt")

 

转载于:https://www.cnblogs.com/donjor/p/4660925.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值