第二章-Python 实现 获取app 冷热启动时间脚本

首先先回顾一下部分需要使用到的adb命令

adb devices 查看连接设备
adb shell "logcat | grep START" 查看监听
adb shell am start -W -n +包/包ity 启动app 并且 查看时间
adb shell am force-stop +包名 关闭app
adb shell input keyevent 3   home 键返回
 
 
代码如下
#/usr/bin/python
#encoding:utf-8
import os
import time
import csv


#app类


class App(object):
def __init__(self):
self.content=''
self.startTime = 0
# 启动app
def LaunchApp(self):
cmd = 'adb shell am start -W -n io.dcloud.com.chuanyuankj.yibaoqrcode/io.dcloud.PandoraEntryActivity '
self.content=os.popen(cmd)
#停止app
def StopApp(self):
cmd = 'adb shell am force-stop io.dcloud.com.chuanyuankj.yibaoqrcode'
os.popen(cmd)
#获取启动时间
def GetTime(self):
for line in self.content.readlines():
if "ThisTime" in line:
self.startTime = line.split(":")[1]
break
return self.startTime


#控制类
class Controller(object):
def __init__(self,count):
self.app = App()
self.counter = count
self.alldata =[("timestamp","elpasetime")]

#单次测试过c
def testprocess(self):
self.app.LaunchApp()
time.sleep(5)
elpasetime=self.app.GetTime()
self.app.StopApp()
time.sleep(3)
currenttime = self.getCurrentTime()
self.alldata.append((currenttime,elpasetime))

#多次执行测试过程
def run(self):
while self.counter > 0 :
self.testprocess()
self.counter = self.counter - 1

#获取当前时间戳
def getCurrentTime(self):
currentTime = time.strftime("%Y-%m-%d %H:%M:%S",time.localtime())
return currentTime

def SaveDataCSV(self):
csvfile =open('startTime22.csv', 'w',encoding='utf8',newline='')
writer = csv.writer(csvfile)
writer.writerows(self.alldata)
csvfile.close()

if __name__ == '__main__':
controller = Controller(10)
controller.run()
controller.SaveDataCSV()

转载于:https://www.cnblogs.com/yyjiangnan/p/6700068.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值