Android应用耗电量统计,无需USB连接

Android应用耗电量统计一直是一个很头疼的问题,手工统计耗时太长,自动化统计又不是非常精准(执行自动化代码需要通过USB连接,而USB又会充电,这就造成统计数据不准)。后来从前辈那里得知可以通过adb connect来实现无线连接,下面就来说说方法。

1、首先找到一台已经root的手机

2、使手机与PC处于同一个网段

3、下载安装Wireless ADB

4、打开Wireless ADB,勾选Wireless ADB,设置端口(默认5555,被占用时设置)

5、打开pc的CMD窗口,输入adb connect 192.168.1.100:5555 回车(详细IP会在Wireless ADB中显示)

6、连接成功

如果提示not implement,则与其他软件冲突,请尝试关掉豌豆夹、360等软件

 

下面来执行统计耗电量的代码,由于要统计应用前台操作一小时耗电量,人工点击显然是不现实的,这里用到了monkey来配合测试。这里只演示整个系统的耗电量,单个应用的耗电量dumpsys较为复杂。

#coding=utf-8
'''
Create on 2015-1-7
python 2.7 for window
@auther: tangdongchu
'''
import os
import sys
import time
import re
import datetime

class monkeyTest():
    
    def __init__(self):
        """ init """
            
    #monkey命令,packageName包名,interval间隔时间单位ms ,frequency执行次数
    def monkeyApp(self,packageName,interval,frequency):
        try:
            os.popen("adb shell monkey -p %s --throttle %s --ignore-crashes --ignore-timeouts --ignore-security-exceptions --ignore-native-crashes --monitor-native-crashes -v -v -v %s >e:\monkeylog\monkeyScreenLog.log" % (packageName, interval, frequency),'r')
        except Exception,e:
            print e

    #获取当前电量
    def getCurrentBattery(self):
        try:
            for Battery in os.popen('adb shell dumpsys battery','r').readlines():
                reList = re.sub('Battery:','',Battery)
                reList = reList.replace('\n','')
                result = re.search('level', reList)
                if result != None :
                    List = reList.split()
                    level=List.pop()#删除第i个元素,并返回这个元素。若调用pop()则删除最后一个元素
                    #print "battery level " + level + "%"
                    return level
                    break
        except Exception,e:
            print e
            
    #获取当前时间,用于计算应用运行时间
    def getCurrentTime(self):
        try:
            currentTime = datetime.datetime.now()
            return currentTime
        except Exception,e:
            print e
           
def main():
    print """"""
    
    
if __name__=="__main__":
    
    packageName = 'ctrip.android.view'  
    myApp = monkeyTest()  
    level = int(myApp.getCurrentBattery())
    runtime = myApp.getCurrentTime()
    myApp.monkeyApp(packageName,500,2500) #0.5秒点一次,运行2500次
    #判断是否执行完成,执行完成后统计耗电量
    for i in range(1, 1000000):
        monkeylog = open('E:\monkeylog\monkeyScreenLog.log')
        try:
            temp = monkeylog.read( )
        finally:
            monkeylog.close( )
        if temp.count('Monkey finished')>0:
            level = int(myApp.getCurrentBattery())-level
            runtime = myApp.getCurrentTime()-runtime
            break
        else:
            time.sleep(2)
    print "run time " + str(runtime)
    print "use battery" + str(level) + "%"

  

 

posted @ 2015-01-07 16:28  一盏黄黄旧旧的灯  阅读(1421)  评论(0编辑  收藏  举报