php 接续留存与留存人数计算
程序员文章站
2024-02-05 23:17:22
...
php 连续留存与留存人数计算
for($i = 0;$i turnround($today,$tomorrow,$flag); $temp = array(); foreach($res as $value){ $inmatch = isset($value['inmatch']) ? json_decode($value['inmatch']) : array(); foreach($inmatch as $val) { if(!in_array($val, $temp)) { array_unshift($temp,$val); } } } $i==0 ? $total = count($temp) : ""; $temp = array_fill_keys($temp, $i); foreach($temp as $k=>$v) { if(array_key_exists($k,$stats)) { $stats[$k] = $stats[$k].",".$v; } else { $stats[$k] = $v; } } $today = $today + 86400; $tomorrow = $tomorrow + 86400; } $strlen = ($interval+1)*2-1; foreach($stats as $v) { if(isset($v)) { strlen(trim($v)) == $strlen ? $num++ : $num; } } $ret['turnround']['all'] = $stats; $ret['turnround']['total'] = $total; $ret['turnround']['stats'] = count($stats); $ret['turnround']['num'] = $num; */ $res = $model->turnround($today,$tomorrow,$flag); $todayPeople = array(); foreach($res as $value){ $inmatch = isset($value['inmatch']) ? json_decode($value['inmatch']) : array(); foreach($inmatch as $val) { if(!in_array($val, $todayPeople)) { array_unshift($todayPeople,$val); } } } $todayNum = count($todayPeople); $atToday = $today + $interval*86400; $atTomorrow = $tomorrow + $interval*86400; $atRes = $model->turnround($atToday,$atTomorrow,$flag); $atPeople = array(); foreach($atRes as $v){ $atInmatch = isset($v['inmatch']) ? json_decode($v['inmatch']) : array(); foreach($atInmatch as $val) { if(!in_array($val, $atPeople)) { array_unshift($atPeople,$val); } } } $same = array_intersect($todayPeople,$atPeople); $atNum= count($same); $ret['turnround']['all'] = $todayPeople; $ret['turnround']['total'] = $todayNum; $ret['turnround']['stats'] = ""; $ret['turnround']['num'] = $atNum;
相关文章
相关视频
专题推荐
-
独孤九贱-php全栈开发教程
全栈 170W+
主讲:Peter-Zhu 轻松幽默、简短易学,非常适合PHP学习入门
-
玉女心经-web前端开发教程
入门 80W+
主讲:灭绝师太 由浅入深、明快简洁,非常适合前端学习入门
-
天龙八部-实战开发教程
实战 120W+
主讲:西门大官人 思路清晰、严谨规范,适合有一定web编程基础学习
下一篇: 怎么在SQLServer计算列和平均值
网友评论
文明上网理性发言,请遵守 新闻评论服务协议
我要评论