php 统计一周的数据,php統計近一周和近30天的用戶數據

2024-01-09 15:59

本文主要是介绍php 统计一周的数据,php統計近一周和近30天的用戶數據,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

先上一張效果圖

go

go

bb73586a28ff48ff79bbdced733d5e44.png

這邊用的是echarts插件http://echarts.baidu.com/

上代碼(小白寫的 別追求什么屌逼代碼,就是冗余的面向過程,不服你來咬我)

按周排按月排

zhou();

function zhou() {

var myChart = echarts.init(document.getElementById('main'));

$(".week").attr("class","btnweek week active");

$(".month").attr("class","btnweek month");

$.get('?act=welcome&op=index&get_data=week',function(data){

myChart.setOption(data);

},'json');

}

function yue(){

var myChart = echarts.init(document.getElementById('main'));

// 異步加載數據

$(".week").attr("class","btnweek week");

$(".month").attr("class","btnweek month active");

$.get('?act=welcome&op=index&get_data=month',function(data){

myChart.setOption(data);

},'json');

}

這些是html代碼,需要引入一個erchars.js文件 可以從上面網址down下來,接下來上統計的代碼

/*

*

* VIP列表

*

*/

public function indexOp()

{

$model_shop = Model('shop');

$model_admin = Model('admin');

$model_member = Model('member');

$model_ap = Model('ap');

$user=$this->getAdminInfo();

$admin=$model_admin->getOneAdmin($user["id"]);

if($admin["admin_area"]){

$condition["areacode"]=array("in",$admin["admin_area"]);

}

//ap

$shop_id = $model_shop->getShopList($condition, '*');

$sid=array();

foreach($shop_id as $shid){

$sid[]=$shid["id"];

}

$condition_ap["shop_id"]=array("in",$sid);

if ($_GET['get_data']=='week') {

echo $this->get_json_arr(6);

}else if ($_GET['get_data']=='month') {

echo $this->get_json_arr(30);

}else{

Tpl::showpage('welcome.index');

}

}

public function get_json_arr($num=6){

$model_shop = Model('shop');

$model_ap = Model('ap');

//統計商鋪

for($i=$num;$i>=0;$i--){

$daystr=date('Y-m-d', strtotime("-$i day"));

$searchstr="TO_DAYS(from_unixtime(addtime,'%Y-%m-%d'))=TO_DAYS('".$daystr."')";

$shopCount=$model_shop->where($searchstr)->count();

$shopDayCountArray[]=$shopCount;

}

//統計ap

for($i=$num;$i>=0;$i--){

$daystr=date('Y-m-d', strtotime("-$i day"));

$searchstr="TO_DAYS(from_unixtime(addtime,'%Y-%m-%d'))=TO_DAYS('".$daystr."')";

$apCount=$model_ap->where($searchstr)->count();

$dateArray[]=date('m-d', strtotime("-$i day"));

$apDayCountArray[]=$apCount;

}

// echo "

";

// print_r($dateArray);die;

if ($num==6) {

$title='近一周的商鋪和AP的統計';

}else{

$title='近一月的商鋪和AP的統計';

}

//處理json包

$json_arr = array(

'title'=>array('text'=>$title),

'tooltip'=>array('trigger'=>'axis'),

'legend'=>array('data'=>array('商鋪','AP')),

'toolbox'=>array(

'show'=>true,

'feature'=>array(

'dataZoom'=>array('yAxisIndex'=>'none'),

'dataView'=>array('readOnly'=>false),

'magicType'=>array('type'=>array('line','bar')),

'restore'=>array(),

'saveAsImage'=>array()

),

),

'xAxis'=>array('type'=>'category','boundaryGap'=>false,'data'=>$dateArray),

'yAxis'=>array('type'=>'value','interval'=>1,'min'=>0,'axisLabel'=>array('formatter'=>'{value} 個')),

'series'=>array(

array(

'name'=>'商鋪',

'type'=>'line',

'data'=>$shopDayCountArray

),

array(

'name'=>'AP',

'type'=>'line',

'data'=>$apDayCountArray

)

)

);

return json_encode($json_arr);exit;

}

我能看懂就行,您們湊合看吧 主要就是在for循環中查詢的數據。。。=_=!

这篇关于php 统计一周的数据,php統計近一周和近30天的用戶數據的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/587663

相关文章

使用Python开发一个Ditto剪贴板数据导出工具

《使用Python开发一个Ditto剪贴板数据导出工具》在日常工作中,我们经常需要处理大量的剪贴板数据,下面将介绍如何使用Python的wxPython库开发一个图形化工具,实现从Ditto数据库中读... 目录前言运行结果项目需求分析技术选型核心功能实现1. Ditto数据库结构分析2. 数据库自动定位3

pandas数据的合并concat()和merge()方式

《pandas数据的合并concat()和merge()方式》Pandas中concat沿轴合并数据框(行或列),merge基于键连接(内/外/左/右),concat用于纵向或横向拼接,merge用于... 目录concat() 轴向连接合并(1) join='outer',axis=0(2)join='o

批量导入txt数据到的redis过程

《批量导入txt数据到的redis过程》用户通过将Redis命令逐行写入txt文件,利用管道模式运行客户端,成功执行批量删除以Product*匹配的Key操作,提高了数据清理效率... 目录批量导入txt数据到Redisjs把redis命令按一条 一行写到txt中管道命令运行redis客户端成功了批量删除k

SpringBoot多环境配置数据读取方式

《SpringBoot多环境配置数据读取方式》SpringBoot通过环境隔离机制,支持properties/yaml/yml多格式配置,结合@Value、Environment和@Configura... 目录一、多环境配置的核心思路二、3种配置文件格式详解2.1 properties格式(传统格式)1.

SQL Server跟踪自动统计信息更新实战指南

《SQLServer跟踪自动统计信息更新实战指南》本文详解SQLServer自动统计信息更新的跟踪方法,推荐使用扩展事件实时捕获更新操作及详细信息,同时结合系统视图快速检查统计信息状态,重点强调修... 目录SQL Server 如何跟踪自动统计信息更新:深入解析与实战指南 核心跟踪方法1️⃣ 利用系统目录

解决pandas无法读取csv文件数据的问题

《解决pandas无法读取csv文件数据的问题》本文讲述作者用Pandas读取CSV文件时因参数设置不当导致数据错位,通过调整delimiter和on_bad_lines参数最终解决问题,并强调正确参... 目录一、前言二、问题复现1. 问题2. 通过 on_bad_lines=‘warn’ 跳过异常数据3

C#监听txt文档获取新数据方式

《C#监听txt文档获取新数据方式》文章介绍通过监听txt文件获取最新数据,并实现开机自启动、禁用窗口关闭按钮、阻止Ctrl+C中断及防止程序退出等功能,代码整合于主函数中,供参考学习... 目录前言一、监听txt文档增加数据二、其他功能1. 设置开机自启动2. 禁止控制台窗口关闭按钮3. 阻止Ctrl +

java如何实现高并发场景下三级缓存的数据一致性

《java如何实现高并发场景下三级缓存的数据一致性》这篇文章主要为大家详细介绍了java如何实现高并发场景下三级缓存的数据一致性,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 下面代码是一个使用Java和Redisson实现的三级缓存服务,主要功能包括:1.缓存结构:本地缓存:使

在MySQL中实现冷热数据分离的方法及使用场景底层原理解析

《在MySQL中实现冷热数据分离的方法及使用场景底层原理解析》MySQL冷热数据分离通过分表/分区策略、数据归档和索引优化,将频繁访问的热数据与冷数据分开存储,提升查询效率并降低存储成本,适用于高并发... 目录实现冷热数据分离1. 分表策略2. 使用分区表3. 数据归档与迁移在mysql中实现冷热数据分

C#解析JSON数据全攻略指南

《C#解析JSON数据全攻略指南》这篇文章主要为大家详细介绍了使用C#解析JSON数据全攻略指南,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、为什么jsON是C#开发必修课?二、四步搞定网络JSON数据1. 获取数据 - HttpClient最佳实践2. 动态解析 - 快速