统计每小时数据的处理

有人问在数据库中得到某个小时有多少条的的统计数据,但是一天24个小时,想让那些时间没有数据的显示0,该如何处理呢?

比如我们得到数组

<?php
$array1=array(
    "00"=>1,
    "01"=>2,
    "22"=>3,
    "23"=>4,
);

?>

凌晨 一点  22点 23点都有数据,可是其他时间没有数据,该怎么自动的填充为0呢?

方式1.循环处理

<?php
$array=array(
    "00"=>1,
    "01"=>2,
    "22"=>3,
    "23"=>4,
);

for ($i=0; $i <=23 ; $i++)
{
    $key=strlen($i)==1?"0".$i:$i;
    $result[$key]=isset($array[$key])?$array[$key]:0;
}
var_dump($result);
?>

因为自增没有前导零,所以要用strlen判断一下。当然这里面可以改进一下,比如用这种方式

<?php
$array=array(
    "00"=>1,
    "01"=>2,
    "22"=>3,
    "23"=>4,
);

for ($i=0; $i <=23 ; $i++)
{
    $key=sprintf(‘%02s‘, $i);;
    $result[$key]=isset($array[$key])?$array[$key]:0;
}
var_dump($result);
?>

采用sprintf弥补它。

第二种方式,直接合并数组

<?php
$array1=array(
    "00"=>1,
    "01"=>2,
    "22"=>3,
    "23"=>4,
);

$array2=array(
    "00"=>0,
    "01"=>0,
    "02"=>0,
    "03"=>0,
    "04"=>0,
    "05"=>0,
    "06"=>0,
    "07"=>0,
    "08"=>0,
    "09"=>0,
    "10"=>0,
    "11"=>0,
    "12"=>0,
    "13"=>0,
    "14"=>0,
    "15"=>0,
    "16"=>0,
    "17"=>0,
    "18"=>0,
    "19"=>0,
    "20"=>0,
    "21"=>0,
    "22"=>0,
    "23"=>0,
    "24"=>0,
);
$result=$array1+$array2;
ksort($result);
var_dump($result);
?>

这样也可以得到结果 数组相加合并 然后排序即可。

结果如下:

时间: 2024-10-29 19:44:48

统计每小时数据的处理的相关文章

使用nginx lua实现网站统计中的数据收集

使用nginx lua实现网站统计中的数据收集 导读 网站数据统计分析工具是各网站站长和运营人员经常使用的一种工具,常用的有 谷歌分析.百度统计和腾讯分析等等.所有这些统计分析工具的第一步都是网站访问数据的收集.目前主流的数据收集方式基本都是基于javascript的.在此简要分析数据收集的原理,并按照步骤,带领大家一同搭建一个实际的数据收集系统. 数据收集原理分析 简单来说,网站统计分析工具需要收集到用户浏览目标网站的行为(如打开某网页.点击某按钮.将商品加入购物车等)及行为附加数据(如某下单

网站统计中的数据收集原理及实现

转载自:http://blog.sina.com.cn/s/blog_62b832910102w5mx.html Avinash Kaushik将点击流数据的获取方式分为4种:log files.web beacons.JavaScript tags和packet sniffers,其中包嗅探器(packet sniffers)比较不常见,最传统的获取方式是通过WEB日志文件(log files):而beacons和JavaScript是目前较为流行的方式,Google Analytics目前就

网站统计中的数据收集原理及实现(share)

转载自:http://blog.codinglabs.org/articles/how-web-analytics-data-collection-system-work.html 网站数据统计分析工具是网站站长和运营人员经常使用的一种工具,比较常用的有谷歌分析.百度统计和腾讯分析等等.所有这些统计分析工具的第一步都是网站访问数据的收集.目前主流的数据收集方式基本都是基于javascript的.本文将简要分析这种数据收集的原理,并一步一步实际搭建一个实际的数据收集系统. 数据收集原理分析 简单来

006-网站统计中的数据收集原理及实现

网站数据统计分析工具是网站站长和运营人员经常使用的一种工具,比较常用的有谷歌分析.百度统计和腾讯分析等等.所有这些统计分析工具的第一步都是网站访问数据的收集.目前主流的数据收集方式基本都是基于javascript的.本文将简要分析这种数据收集的原理,并一步一步实际搭建一个实际的数据收集系统. 数据收集原理分析 简单来说,网站统计分析工具需要收集到用户浏览目标网站的行为(如打开某网页.点击某按钮.将商品加入购物车等)及行为附加数据(如某下单行为产生的订单金额等).早期的网站统计往往只收集一种用户行

使用Spark进行搜狗日志分析实例——统计每个小时的搜索量

1 package sogolog 2 3 import org.apache.spark.rdd.RDD 4 import org.apache.spark.{SparkConf, SparkContext} 5 6 /** 7 * 统计每小时搜索次数 8 */ 9 /* 10 搜狗日志示例 11 访问时间(时:分:秒) 用户ID [查询词] 该URL在返回结果中的排名 用户点击的顺序号 用户点击的URL 12 00:00:00 2982199073774412 [360安全卫士] 8 3 d

SQL Server 执行计划利用统计信息对数据行的预估原理二(为什么复合索引列顺序会影响到执行计划对数据行的预估)

本文出处:http://www.cnblogs.com/wy123/p/6008477.html 关于统计信息对数据行数做预估,之前写过对非相关列(单独或者单独的索引列)进行预估时候的算法,参考这里. 今天来写一下统计信息对于复合索引在预估时候的计算方法和潜在问题. 本文原形来自于是个实际业务问题,某SQL在利用一个符合索引做查询的时候,发现始终会出现预估误差较大的情况, 而改变复合索引的列顺序,这个预估行数的误差会发生变化, 也就是说,Create  index idx_index1 ON T

统计方形(数据加强版)

洛谷P2241 统计方形(数据加强版) 我的做法是在求矩形时(包括正方形),用的是长从1~m,宽从1~n枚举的,但是数学方法往往能起到四两拨千斤的效果,其实矩形的个数就是Cn+22  *  Cm+22.因为确定一个矩形只需要确定它的两个端点就可以了,为啥要n+1,m+1呢?因为矩形边长可以为1,就是另一个点选空.若只求长方形,用容斥原理即可. #include<bits/stdc++.h> using namespace std; unsigned long long n,m; unsigne

SQL Server 执行计划利用统计信息对数据行的预估原理以及SQL Server 2014中预估策略的改变

前提  本文仅讨论SQL Server查询时, 对于非复合统计信息,也即每个字段的统计信息只包含当前列的数据分布的情况下, 在用多个字段进行组合查询的时候,如何根据统计信息去预估行数的. 利用不同字段的统计信息做数据行数预估的算法原理,以及SQL Server 2012和SQL Server 2014该算法的差异情况, 这里暂时不涉及复合统计信息,暂不涉及统计信息的更新策略及优化相关话题,以及其他SQL Server版本计算方式. 统计信息是什么 简单说就是对某些字段的数据分布的一种描述,让SQ

shell cat 命令的 不靠谱使用,导致hive 表中的小时数据,每隔几天就会缺失一个小时的

现象:hive 表中的小时数据,每隔几天就会缺失一个小时的,最后发现时在做数据聚合cat的时候,失败,导致: 修改脚本,做下面的方案,解决了: ##merge 5min data into hour data                                                                                                                        cat $datapath/news_5min_$x