游戏数据分析中“次日留存率”与“游戏生命周期第N天上线率”的SAS实现
在游戏行业,次日留存率是个很重要的指标,对于评价一款游戏的优劣具有很重要的参考价值。
下面先看以下相关的定义:
用户留存:统计时间区间内,新登用户在随后不同时期的登录使用情况。
日次留存率:日新登用户在次日( 不含首次登录当天) 登录的用户数占新登用户比例。
解决问题:
1、用户对于游戏的适应性如何;
2、评估渠道用户质量;
3、投放渠道效果评估;
4、用户对于游戏的粘性如何;
5、新登用户什么时期流失会加剧。
(以上内容来自TalkingData的《移动游戏运营数据分析指标白皮书》)
可以看出,次日留存率主要关注的是在某一日(比如2013-8-25)新登录的用户,在第二天(即2013-8-26)登录的用户数占昨日(2013-8-25)新登用户比例的情况。
接着来看“生命周期第N天上线率”的定义:
统计时间区间内,所有用户在游戏生命周期第N天登录的用户数占所有用户的比例。
解决问题:
次日留存率能解决的问题,该指标都沾些边。但该指标的主要用途还是在评价某些游戏运营过程中设置的“连续登陆送奖励”等类似策略的有效性。
下面就用一个例子来演示下如何通过SAS求出这两个指标值。
数据如下(USERID:用户ID;LOGINLONG:登陆时长(S);RECHARGE:充值金额;TIME:登录时间):

程序如下:
***导入数据***;
proc import out=test datafile="H:\test.xls" dbms=excel replace;
sheet="sheet1$";
mixed=yes ;
scantext=yes;
run; ***计算生命周期第2天上线率***;
proc sort data=test;by userid time;run; proc means data=test nway noprint;
class userid;
var time;
output out=minmax(keep=userid min_time max_time) min=min_time max=max_time;
run; data minmax;
set minmax;
format time date9.;
do time=min_time to max_time;
output;
end;
drop min_time max_time;
run; data temp;
merge minmax(in=a) test;
by userid time;
if a;
run; data temp;
set temp;
if loginlong=. or recharge=. then login=0;else login=1;
by userid;
if first.userid then timeline=1;
else timeline+1;
run; %macro timeline; proc sql noprint;
select count(distinct timeline) into:num
from temp;
quit; %do i=1 %to # proc sql noprint;
create table temp1 as
select timeline,count(distinct userid) as tnum
from temp
where timeline=&i and login=1;
quit; proc datasets nolist;
append base=temp2 data=temp1;
delete temp1;
quit; %end; data result1;
set temp2;
by timeline;
if first.timeline then output;
run; proc datasets nolist;delete temp2 minmax;quit;run; %mend; %timeline; data _null_;
set result1;
if _n_=1 then do;
call symputx('snum',tnum);
end;
run; data result1;
set result1;
format rate 5.2;
rate=tnum/&snum.*100;
label timeline='游戏生命周期第N天' tnum='上线人数' rate='生命周期第N天上线率(%)';
run; ***计算次日留存率***;
proc sql;
create table temp1 as
select time,count(distinct userid) as new_tnum
from temp
where timeline=1
group by time; create table temp2 as
select time-1 as time,count(distinct userid) as mnum
from temp
where login=1 and timeline=2
group by time;
quit; data result2;
merge temp1 temp2;
format time date9.;
by time;
run; data result2;
set result2;
rate=mnum/new_tnum*100;
label time='日期' new_tnum='新增用户数' rate='次日留存率(%)';
drop mnum;
run; proc datasets nolist;delete temp temp1 temp2;quit;run;
结果:
(1)次日留存率

(2)生命周期第N天上线率

p.s.:因为是测试程序用的数据,所以谈不上通过数据可视化来发现某些有价值的东西。但至少提供了一个可行的方向。如果有真实的游戏数据来做测试,或许可以发现一些有趣的现象。一般来说,生命周期第N天上线率与传统意义上的留存率是存在相关关系的。一般不会出现一款游戏的次日留存率节节走高,而生命周期第2天上线率下降的现象。
游戏数据分析中“次日留存率”与“游戏生命周期第N天上线率”的SAS实现的更多相关文章
- C/C++——C++变量的作用域与生命周期,C语言中变量的作用域和生命周期
全局变量 作用域:全局作用域(全局变量只需在一个源文件中定义,就可以作用于所有的源文件.) 生命周期:程序运行期一直存在 引用方法:其他文件中要使用必须用extern 关键字声明要引用的全局变量. 内 ...
- 如何在web.config文件中配置Session变量的生命周期
实例说明:在网上购物商城中,为了维护在线购物环境,一般只有注册会员才可以购买商品.实现购物功能时,先通过Session变量记录会员的登录名,然后在购买商品页面通过判断会员是否登录确定其能否购买商品. ...
- Spring中与bean有关的生命周期
前言 记得以前的时候,每次提起Spring中的bean相关的生命周期时,内心都无比的恐惧,因为好像有很多,自己又理不清楚,然后看网上的帖子,好像都是那么一套,什么beanFactory啊,aware接 ...
- 【老孟Flutter】Flutter 中与平台相关的生命周期
老孟导读:关于生命周期的文章共有2篇,一篇(此篇)是介绍 Flutter 中Stateful 组件的生命周期. 第二篇是 Flutter 中与平台相关的生命周期, 博客地址:http://laomen ...
- Flutter--Flutter中Widget、App的生命周期
前言 在App的开发过程中,我们通常都需要了解App以及各个页面的生命周期,方便我们在App进入前台时启动一些任务,在进入后台后暂停一些任务.同时,各个页面的生命周期也很重要,每个页面消失时要做一些内 ...
- 详解Spring中Bean的作用域与生命周期
摘要:在利用Spring进行IOC配置时,关于bean的配置和使用一直都是比较重要的一部分,同时如何合理的使用和创建bean对象,也是小伙伴们在学习和使用Spring时需要注意的部分,所以这一篇文章我 ...
- Unity脚本中各函数成员的生命周期
在学习Unity时,掌握如何编写脚本是必须掌握的一项基本技能.但是关于Unity的游戏脚本中各函数的生命周期是怎样开始和结束的,它们的执行顺序是如何安排的?这一点我们要清楚的了解. 我们知道Unity ...
- Unity3D热更新之LuaFramework篇[06]--Lua中是怎么实现脚本生命周期的
前言 用c#开发的时候,新建的脚本都默认继承自Monobehaviour, 因此脚本才有了自己的生命周期函数,如Awake,Start, Update, OnDestroy等. 在相应的方法中实现游戏 ...
- Spring中Bean的作用域、生命周期
Bean的作用域.生命周期 Bean的作用域 Spring 3中为Bean定义了5中作用域,分别为singleton(单例).protot ...
随机推荐
- 8个让DevOps转型取得成功的关键步骤
关注嘉为科技,获取运维新知 在数字化时代,企业需要更快更灵活的交付来支持业务运营,这种迫切的需求促成了DevOps的高速发展,成为了企业获得竞争优势的关键.尽管大家都知道DevOps给业务带来的好 ...
- java poi excel操作 把第一列放到最后去
@Override public void adjustExcleColumnPosition(String filePath,int col) throws Exception{ File file ...
- 从rnn到lstm,再到seq2seq(一)
rnn的的公式很简单: 对于每个时刻,输入上一个时刻的隐层s和这个时刻的文本x,然后输出这个时刻的隐层s.对于输出的隐层s 做个ws+b就是这个时刻的输出y. tf.scan(fn, elems, i ...
- 八大排序算法——选择排序(动图演示 思路分析 实例代码Java 复杂度分析)
一.动图演示 二.思路分析 1. 第一个跟后面的所有数相比,如果小于(或小于)第一个数的时候,暂存较小数的下标,第一趟结束后,将第一个数,与暂存的那个最小数进行交换,第一个数就是最小(或最大的数) ...
- Android 音视频深入 七 学习之路的总结和资料分享
说个实话一开始我对基于Android如何开发音视频很迷茫,甚至对音视频开发都不是很明白,我看了Android 音视频开发入门指南 http://blog.51cto.com/ticktick/1956 ...
- python之路---面向对象编程(一)
一.设计思想的发展 面向机器(代码复杂,效率低,学习成本高,开发周期长)-------->面向过程(扩展性差,不适用多变的需求改变)----------->面向对象(扩展性好,但是可控性差 ...
- leetcode python 012 hard 合并k个有序链表
#[LeetCode] Merge k Sorted Lists 合并k个有序链表(升序) import numpy as npimport time class Node(object): d ...
- leetcode python 006
## 改为z型字符串def change_to_z(s,n): ## 字符串不能生成完整的区,用空格补全 b=len(s)%(2*n-2) if b!=0: s+=' ...
- mongoose的关联查询 :populate
mongoose关联查询从3.2版本开始支持 基本用法如下: var studentSchema = new Schema({ name:String, age:String, school:{ ty ...
- 使用css时的一些技巧及注意事项
<!-- TITLE: 使用css时的一些技巧及注意事项 --> # CSS推荐书写顺序: 1. 位置属性(position, top, right, z-index, display, ...