统计每小时数据的处理
有人问在数据库中得到某个小时有多少条的的统计数据,但是一天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); ?>
这样也可以得到结果 数组相加合并 然后排序即可。
结果如下:
分类:
杀鸡要用宰牛刀
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 一个奇形怪状的面试题:Bean中的CHM要不要加volatile?
· [.NET]调用本地 Deepseek 模型
· 一个费力不讨好的项目,让我损失了近一半的绩效!
· 微软正式发布.NET 10 Preview 1:开启下一代开发框架新篇章
· 没有源码,如何修改代码逻辑?
· PowerShell开发游戏 · 打蜜蜂
· 在鹅厂做java开发是什么体验
· WPF到Web的无缝过渡:英雄联盟客户端的OpenSilver迁移实战