精华内容
下载资源
问答
  • 要做一个小程序,这个小程序,随机启动,能在人们使用手机时记录使用时间app统计一天人们玩手机时间。求指教
  • 本人在做APP性能测试的时候,需要统计一下APP启动时间和进入首页的时间,之前采取的方案是图片做对比,后来采取了录屏,效果都不是很理想,在参考了网上关于手机log分析手机启动activity的教程,自己写了一个多线程...

    本人在做APP性能测试的时候,需要统计一下APP启动时间和进入首页的时间,之前采取的方案是图片做对比,后来采取了录屏,效果都不是很理想,在参考了网上关于手机log分析手机启动activity的教程,自己写了一个多线程类通过不停地启动关闭APP,同时分析log中关于activity的lauch时间得到需要的数据。测试了一下效果很不错,分享代码,供大家参考。

    package monkeytest;
     
    import java.io.BufferedReader;
    import java.io.IOException;
    import java.io.InputStream;
    import java.io.InputStreamReader;
    import java.util.regex.Matcher;
    import java.util.regex.Pattern;
    import source.AppLocalMySql;
    import source.Common;
     
    public class LauchTime extends Thread {
    	public static String ADB_PATH = Common.ADB_PATH;;
    	public static String package_name = Common.PAGEKAGE;
    	public static String test_name = "normal";
    	public static Pattern pattern = Pattern.compile("\\+.+?ms");
    	public static boolean LauchKey = false;
     
    	public static void main(String[] args) {
    		// String timess = args[0];
    		// int times = Common.getInstance().changeStringToInt(timess);
    		execCmdAdb("adb logcat -c");
    		Common.getInstance().sleep(2000);
    		LauchTime lauchTime = new LauchTime();
    		lauchTime.start();// 启动logcat统计线程
    		StartApp startApp = new StartApp();// 获取startAPP实例
    		for (int i = 0; i < 5; i++) {
    			startApp.startJuziApp();// 启动APP
    			Common.getInstance().sleep(9000);
    			startApp.stopJuziApp();// 关闭APP
    			Common.getInstance().sleep(1000);
    		}
    		lauchTime.stopLauch();// 结束统计
    	}
     
    	@Override
    	public void run() {
    		execCmdAdb("adb logcat");
    	}
     
    	/**
    	 * 停止logcat线程
    	 */
    	public void stopLauch() {
    		LauchTime.LauchKey = true;
    	}
     
    	/**
    	 * 执行adb命令
    	 * 
    	 * @param cmd
    	 *            命令内容
    	 * @param fileName
    	 *            输入文件路径
    	 */
    	private static void execCmdAdb(String cmd) {
    		System.out.println("正在执行:" + cmd);
    		String OSname = System.getProperty("os.name");
    		try {
    			Process p = null;
    			if (OSname.contains("Mac")) {
    				p = Runtime.getRuntime().exec(Common.ADB_PATH + cmd);
    			} else {
    				p = Runtime.getRuntime().exec("cmd /c " + cmd);
    			}
    			// 正确输出流
    			InputStream input = p.getInputStream();// 创建并实例化输入字节流
    			BufferedReader reader = new BufferedReader(new InputStreamReader(input));// 先通过inputstreamreader进行流转化,在实例化bufferedreader,接收内容
    			String line = "";
    			while ((line = reader.readLine()) != null) {// 循环读取
    				if (LauchKey) {
    					p.destroy();// 结束线程
    					reader.close();// 此处reader依赖于input,应先关闭
    					input.close();
    					return;
    				}
    				//截取到log信息,分别统计两个activity的时间
    				if (line.contains("Displayed")) {
    					if (line.contains("SplashActivity")) {
    						double time = getLauchTime(line);
    						AppLocalMySql.getInstance().saveLauchTime(test_name, package_name, "SplashActivity", time);
    					}
    					if (line.contains("HomeActivity")) {
    						double time = getLauchTime(line);
    						AppLocalMySql.getInstance().saveLauchTime(test_name, package_name, "HomeActivity", time);
    					}
    				}
    			}
    			reader.close();// 此处reader依赖于input,应先关闭
    			input.close();
    			// 错误输出流
    			InputStream errorInput = p.getErrorStream();// 创建并实例化输入字节流
    			BufferedReader errorReader = new BufferedReader(new InputStreamReader(errorInput));// 先通过inputstreamreader进行流转化,在实例化bufferedreader,接收内容
    			String eline = "";
    			while ((eline = errorReader.readLine()) != null) {// 循环读取
    				output(eline);// 输出
    			}
    			errorReader.close();// 此处有依赖关系,先关闭errorReader
    			errorInput.close();
    		} catch (
     
    		IOException e) {
    			Common.getInstance().output("执行" + cmd + "失败!");
    			e.printStackTrace();
    		}
    	}
     
    	/**
    	 * 获取启动时间
    	 * 
    	 * @param line
    	 *            截取到的log信息
    	 * @return 返回double时间,单位s,默认0.00
    	 */
    	public static double getLauchTime(String line) {
    		Matcher matcher = pattern.matcher(line);
    		if (matcher.find()) {
    			line = matcher.group(0);
    			line = line.substring(1, line.length() - 2);
    			line = line.replace("s", ".");
    			if (!line.contains(".")) {
    				line = "0." + line;
    			}
    			double time = Common.getInstance().changeStringToDouble(line);
    			return time;
    		}
    		return 0.00;
    	}
     
    	public static void output(String text) {
    		System.out.println(text);
    	}
     
    	public static void output(Object... object) {
    		if (object.length == 1) {
    			output(object[0].toString());
    			return;
    		}
    		for (int i = 0; i < object.length; i++) {
    			System.out.println("第" + (i + 1) + "个:" + object[i]);
    		}
    	}
    }
    

    中间startAPP类用到的方法如下:

    /**
    	 * 启动橘子APP
    	 */
    	public void startJuziApp() {
    		if (Monkey.package_name.contains("happyjuzi")) {
    			execCmdAdb("adb shell am start -n com.happyjuzi.apps.juzi/.SplashActivity");
    		} else if (Monkey.package_name.contains("article.news")) {
    			execCmdAdb("adb shell am start -n com.ss.android.article.news/.activity.SplashBadgeActivity");
    		}
    	}
     
    	public void stopJuziApp() {
    		if (Monkey.package_name.contains("happyjuzi")) {
    			execCmdAdb("adb shell am force-stop com.happyjuzi.apps.juzi");
    		} else if (Monkey.package_name.contains("article.news")) {
    			execCmdAdb("adb shell force-stop com.ss.android.article.news");
    		}
    	}
    

    往期文章精选

    1. java一行代码打印心形
    2. Linux性能监控软件netdata中文汉化版
    3. 接口测试代码覆盖率(jacoco)方案分享
    4. 性能测试框架
    5. 如何在Linux命令行界面愉快进行性能测试
    6. 图解HTTP脑图
    7. 写给所有人的编程思维
    8. 测试之JVM命令脑图
    9. 将json数据格式化输出到控制台
    10. 如何测试概率型业务接口
    11. “双花”BUG的测试分享

    公众号地图 ☢️ 一起来~FunTester

    转载于:https://my.oschina.net/u/3973795/blog/3088968

    展开全文
  • 最早的启动app时间就是昨天 select count(*) from (select min(createdatms) mintime from ext_startup_logs where appid = 'sdk34734' group by deviceid having mintime >= getdaybegin(-2) and ...

    用户行为分析
    新增用户
    1.前天的新增用户
    最早的启动app的时间就是昨天

    		select
    
    count(*)
    
    from
    
    (select min(createdatms) mintime
    
    from ext_startup_logs
    
    where appid = 'sdk34734'
    
    group by deviceid
    
    having mintime >= getdaybegin(-2) and mintime < getdaybegin(-1)
    
    )t ;
    
    	2.本周的新增用户
    		最早的启动app的时间在这一周之内
    
    	select
    count(*)
    from
    (select min(createdatms) mintime
    from ext_startup_logs
    where appid = 'sdk34734'
    group by deviceid
    having mintime >= getweekbegin() and mintime < getweekbegin(1)
    ) t ;
    
    	3.本月的新增用户
    		最早的启动app的时间在这一月之内
    
    	select
    count(*)
    from
    (select min(createdatms) mintime
    from ext_startup_logs
    where appid = 'sdk34734'
    group by deviceid
    having mintime >= getmonthbegin() and mintime < getmonthbegin(1)
    )t ;
    
    活跃用户
    	1.前天的日活
    
    	select
    
    count(distinct deviceid)
    
    from ext_startup_logs
    
    where appid = 'sdk34734'
    
    and createdatms >= getdaybegin(-2) and createdatms < getdaybegin(-1);
    
    	2.本周的周活
    
    	select
    count(distinct deviceid)
    from ext_startup_logs
    where appid = 'sdk34734'
    and createdatms >= getweekbegin() and createdatms < getweekbegin(1);
    
    	3.本月的月活
    
    	select
    count(distinct deviceid)
    from ext_startup_logs
    where appid = 'sdk34734'
    and createdatms >= getmonthbegin() and createdatms < getmonthbegin(1);
    
    	4.本周每一天的日活
    
    	select
    formattime(createdatms,'yyyy/MM/dd') day ,count(distinct deviceid)
    from ext_startup_logs
    where appid = 'sdk34734'
    and createdatms >= getweekbegin() and createdatms < getweekbegin(1)
    group by formattime(createdatms,'yyyy/MM/dd');
    
    	5.半年的每月的月活
    
    select
    formattime(createdatms,'yyyyMM') stdate, count(distinct deviceid) stcount
    from ext_startup_logs
    where ym >= formattime(getmonthbegin(-5),'yyyyMM') and appid ='sdk34734'
    group by formattime(createdatms,'yyyyMM');
    
    	6.连续三周的活跃用户
    
    	select deviceid , count(distinct(formattime(createdatms,'yyyyMMdd',0))) c
    from ext_startup_logs
    where appid = 'sdk34734'
    and concat(ym,day) >= formattime(getweekbegin(-2),'yyyyMMdd')
    group by deviceid
    having c = 3;
    
    沉默用户
    	沉默用户(只访问过一次,超过2天没访问)
    
    	select
    count(*)
    from
    (select deviceid , count(createdatms) dcount,min(createdatms) dmin
    from ext_startup_logs
    where appid = 'sdk34734'
    group by deviceid
    having dcount = 1 and dmin < getdaybegin(-1)
    )t;
    
    启动次数
    	前天的app启动次数
    
    	select
    count(deviceid)
    from ext_startup_logs
    where appid = 'sdk34734'
    and ym = formattime(getdaybegin(),'yyyyMM') and day = formattime(getdaybegin(-1),'dd');
    
    版本分布
    	前天每个版本的使用用户数
    
    	select
    appversion,count(distinct deviceid)
    from ext_startup_logs
    where appid = 'sdk34734'
    and ym = formattime(getdaybegin(),'yyyyMM') and day = formattime(getdaybegin(-1),'dd')
    group by appversion;
    
    	本周每天各版本版本使用用户数
    
    	select
    formattime(createdatms,'yyyyMMdd'),appversion , count(distinct deviceid)
    from ext_startup_logs
    where appid = 'sdk34734'
    and concat(ym,day) >= formattime(getweekbegin(),'yyyyMMdd')
    group by formattime(createdatms,'yyyyMMdd'), appversion;
    
    用户留存
    	周留存:本周访问并且是上周的新增用户
    
    	select
    
    distinct s.deviceid
    
    from ext_startup_logs s
    
    where appid = 'sdk34734'
    
    and concat(ym,day) >= formattime(getweekbegin(),'yyyyMMdd')
    
    and concat(ym,day) < formattime(getweekbegin(1),'yyyyMMdd')
    
    and deviceid in (
    
    select distinct t.deviceid
    
    from (
    
    select tt.deviceid , min(tt.createdatms) mintime
    
    from ext_startup_logs tt
    
    where tt.appid = 'sdk34734'
    
    group by tt.deviceid having mintime >= getweekbegin(-1) and mintime < getweekbegin()
    
    ) t); 
    
    新鲜度分析
    	前天新增用户/前天的活跃用户
    自由主题
    
    展开全文
  • 需求:统计手机app几种场景的响应时间,包括前后台,这里简化为统计某个手机app登录的时间分析:为么不能手工统计?1:场景多;2:压测情况多;3:希望借助模拟器多开;两两组合情况较多方案:使用自动化来实现,...

    需求:统计手机app几种场景的响应时间,包括前后台,这里简化为统计某个手机app登录的时间

    分析:为么不能手工统计?

    1:场景多;2:压测情况多;3:希望借助模拟器多开;两两组合情况较多

    方案:使用自动化来实现,点击登录按钮开始计时,登录完毕查找元素出现再次计时,从而得到时间差

    实践:

     //前方已省略app配置相关
       //登录输入用户名密码
       driver.findElement(By.id("com.lc.oaplus:id/username")).sendKeys("username");
       driver.findElement(By.id("com.lc.oaplus:id/password")).sendKeys("1");
      
       long startTime=0,endTime=0;
       String psStr="";
      
       //获取开始时间,点击登录按钮
       startTime=System.currentTimeMillis();
       driver.findElement(By.id("com.lc.oaplus:id/btn_login")).click();
      
       //成功点击待办发文这几个字后,获取结束时间
       driver.findElement(By.xpath("//android.widget.TextView[@text='待办发文']")).click();
       endTime=System.currentTimeMillis();
       System.out.println("登录所需要的时间为:"+(endTime-startTime)/1000.00+"秒");

    运行结果:登录所需要的时间为:6.024秒

    结果分析:运行结果6秒,人工预估大约1秒,所以程序存在问题,推测因程序需要通过appium操作app,推测定位花费时间,进行验证,将获取开始时间放在登录点击之后,即

    //获取开始时间,点击登录按钮
        driver.findElement(By.id("com.lc.oaplus:id/btn_login")).click();
        startTime=System.currentTimeMillis();

    再次运行查看结果:登录所需要的时间为:2.713秒

    结果分析:时间减少一半多,故而定位花费时间较多,需要优化当前代码,登录场景开始时间的获取可以放在登录按钮定位点击之后,结束时间使用getpagesource()查看是否有相关内容进行获取

    优化代码如下:

    //点击登录按钮计时,因为登录按钮查询花费时间,所以点击完按钮后开始计时
       driver.findElement(By.id("com.lc.oaplus:id/btn_login")).click();
       startTime=System.currentTimeMillis();
       System.out.println(startTime);
      
       //若是通过找元素click来查找,因为定位要花费时间,明显比人眼查看时间花费多,所以使用循环查询源码
       for (int i = 0; i < 10000; i++) {
        psStr=driver.getPageSource();
        if(psStr.contains(psStr.contains("待办发文")){
         endTime=System.currentTimeMillis();
         break;
        }
     }  
        System.out.println(endTime);
       System.out.println("登录所需要的时间为:"+(endTime-startTime)/1000.00+"秒");

    运行查看结果:登录所需要的时间为:2.48秒

    这个时间个人以为可能会稍微准确点,到底是否准确还需要后期进行实践比对,请各位大神指正。若各位有更好统计手机app前台响应时间的方法,请指教。

    
    展开全文
  •  如今,大家每天都有大量时间花在手机上,但是,大家有没有想过自己的时间都花在哪些App上了呢?相信很多人都有这样的需求,不过iOS系统本身并不能显示每个App的运行时间和次数,因此,本人写了这样一个小工具,...

    时间都去哪儿了?开源一个统计iPhone上App运行时间和打开次数的小工具

             如今,大家每天都有大量时间花在手机上,但是,大家有没有想过自己的时间都花在哪些App上了呢?相信很多人都有这样的需求,不过iOS系统本身并不能显示每个App的运行时间和次数,因此,本人写了这样一个小工具,可以在后台进行监控当前使用的App,对App的打开次数和运行时间进行统计,可以显示今日、本周、或全部统计结果,并能按打开次数、运行时长排序。

           程序使用的是私有API,因此请勿将本文中提到的方法用于需要发布到AppStore的应用。不过在真机上运行代码,并不需要越狱,只需要有开发者证书即可,因此有证书的朋友可以部署代码到设备上娱乐下。

           程序原理很简单,首先是播放无声音乐,使程序能保持后台运行,其次启动一个计时器,持续获取当前前台运行的App名称,当前台运行的App发生改变时,即写一条记录到数据库,然后监控设备的锁屏消息,当设备锁屏时,暂停计时器,当设备打开锁屏时,继续计时器。如果设备重启,需要重新打开一次程序,统计才能继续进行。

          运行效果如下:

                  

          程序的要点如下:

    (1)播放无声音乐

           使用开源代码MMPDeepSleepPreventer

     

    (2)获取前台运行App bundleId及App名称

           获取前台运行的App Bundle Id:SBFrontmostApplicationDisplayIdentifier

           获取App 名称 :SBSCopyLocalizedApplicationNameForDisplayIdentifier

           获取App图标:SBSCopyIconImagePNGDataForDisplayIdentifier

           具体使用方法参见《iphone SprintBoard部分私有API总结》 及 代码。

    (3)监控设备锁屏消息

           使用CFNotificationCenterAddObserver对"com.apple.springboard.lockcomplete"和"com.apple.springboard.lockstate"进行监控。根据得到的状态,可以知道设备是锁屏还是打开非锁屏。

       代码下载:https://github.com/gugupluto/iOSAppTime       

    ios系统升级,这里的一些私有参数已无效
    展开全文
  • 目标打卡APP时间管理类型APP,目前功能较少,有基本的目标清单、目标花费时间记录、花费时间统计展示右侧release已发布编译好的安装包,可进行下载有需要的小伙伴,可以自行拉取进行自己的特定需求开发开发由来在...
  • 相信很多人都有这样的需求,不过iOS系统本身并不能显示每个App的运行时间和次数,因此,本人写了这样一个小工具,可以在后台进行监控当前使用的App,对App的打开次数和运行时间进行统计,可以显示今日、本周、或全部...
  • 时间分析APP描述

    2020-08-06 11:32:50
    时间分析APP 这是我在大创中做过的项目,功能主要是对手机中应用的使用时长做一个统计,点子虽然不新颖,但是我也因此学到了android编程的知识,也算是离自己每天都接触的手机更近了一步。 在这个项目中主要用到的...
  • 如果是请专门的手机网站开发人员去做的话,可能需要花费比较长的时间,并且做出来的效果不一定令人满意,并且需要消耗成本。 如今,对于这一点,已经有了非常简单的解决方案,那就是自己封装app,下面来看具体的操作步骤...
  • Android下APP耗电量统计实现

    千次阅读 2015-10-07 12:49:18
    设置中的电量统计即系统调用内部API的统计结果。 http://www.autooo.net/classid164-id138050.html:智能手机的耗电特征及APP耗电量测试的...我们不免也有另一种担心,现在的智能手机的待机时间已经是一个短板,未来的
  • 相信很多人都有这样的需求,不过iOS系统本身并不能显示每个App的运行时间和次数,因此,本人写了这样一个小工具,可以在后台进行监控当前使用的App,对App的打开次数和运行时间进行统计,可以显示今日、本周、或全部...
  • 手机APP测试流程&方法

    万次阅读 多人点赞 2018-10-05 20:42:35
    APP测试基本流程 1.1流程图 1.2测试周期 测试周期可按项目的开发周期来确定测试时间,一般测试时间为两三周(即15个工作日),根据项目情况以及版本质量可适当缩短或延长测试时间。正式测试前先向主管确认...
  • 记录手机app的使用时长

    千次阅读 2015-07-21 13:27:15
    老牌时间记录器,可以自定义分类,统计和回顾也很清晰 iTunes App Store 的 iPhone,iPod touch和 iPadaTimeLoggeraTimeLogger出安卓版啦!(2013/12/3更新)2.Evertracker,记录方便,点击单个条目而已,其他app需要输入...
  • 一、 APP测试基本流程 1、流程图 2、测试周期 测试周期可按项目的开发周期来确定测试时间,一般测试时间为两三周(即15个工作日),根据项目情况以及版本质量可适当缩短或延长测试时间。正式测试前先向主管确认...
  • 节省苹果手机电源,优化APP耗电

    千次阅读 2016-03-11 13:53:58
    在设置→通用→用量中,你可以看到上次完全充电后的时间统计,包括“使用时间”和“待机时间”。正常情况下,你的使用时间应该明显低于待机时间,除非你无时无刻不在用手机。如果不是的话,说明你的电池使用存在问题...
  • 最近一段时间工作中需要测试android手机app的耗电量。我的测试思路是使用adb命令行工具来统计电池使用信息。 如果你是第一次接触adb命令,可以看一下我之前的文章:Android测试中常用的adb命令。 adb命令用wifi方式...
  • YouDianCMS即友点企业网站管理系统集电脑站 手机站 微信站 APP 小程序五合一,数据自动同步,降低人力维护成本;共用一个管理后台,只要一个虚拟主机,有效节约空间投资。系统采用PHP MYSQL,具有操作简单、轻便快捷...
  • 学生信息管理系统手机APP的开发记录(一) 因为刚开始学做安卓开发,所以想要自己做一个项目来快速熟悉开发技术。如果平时只是去做一些很简单的,或是很明确的功能开发,就会出现技术不能提升的问题。所以从今天开始...
  • APP_COUNT简介

    千次阅读 2013-08-09 16:21:59
    APP_COUNT提供Android应用的用户信息统计,可以在你的Android应用里调用App_Count第三方jar包里的功能 ,获取用户手机IMEI码作为用户的唯一标识,也可以获取用户手机型号,操作系统版本,Android应用启动次 数,...
  • app使用情况

    2020-11-29 18:37:23
    我们统计了最近一周的手机使用时间,从每天的使用情况、app使用情况等方面分析我们都被手机的什么内容吸引? first 平均每天7小时的手机使用时长,可以看出这是低头族的一员;其中3/4的时间都是画在了娱乐上面,仅...
  • 为了改掉自己的这个毛病,我找到了手机上的Forest APP。这是一个简单好用的计时APP,当自己在学习的时候设定一个45分钟的时钟,这样在手情不自禁打开知乎的时候就会想到那个倒计时的时钟,阻止自己在走神的路上越走...
  • 移动端APP测试

    2019-12-14 10:01:22
    测试周期可按项目的开发周期来确定测试时间,一般测试时间为两三周(即15个工作日),根据项目情况以及版本质量可适当缩短或延长测试时间。 测试资源 测试任务开始前,检查各项测试资源是否完备: 产品功能需求文档...
  • 更支持对您手机的应用APP设定应用锁,对时间锁定,防沉迷,进行使用时间限制,控制手机时间,并每日对您使用的应用时间排行统计,帮助您远离手机诱惑更好的自律,更好的管理时间,对时间规划,提升个人效率,完成您...
  • 统计数据显示,男性的手机中平均会装40个应用软件,而女性的手机中则有70个,与男性相比,对于移动互联网的依赖性,女性用户特点更为鲜明,其发展势头也最为迅猛。那么,女性APP开发中有哪些应用?  导购类...
  • 以前各大手机视频 App 一般都有运营商的流量包套餐.当用户产生这样的业务行为时,运营商便获取了一系列的用户行为日志. 这条日志是一条获取视频用户手机号码的日志.日志的类型很多,当时做的主要工作是对这个类型的...

空空如也

空空如也

1 2 3 4 5 ... 11
收藏数 215
精华内容 86
关键字:

手机时间统计app