今日开发本站需要用到按时间归档文章的功能,即按文档发布时间将文章文类,以实现检索和统计功能,于是自己写了一个, 现分享给大家,相信大家工作和学习中有可能会用到,实现原理很简单,即取出文章发布时间戳的年月(年月日也可以,自 决定),生成相应的统计数据,调用时只需要知道该数组元素所标识时间的起始时间戳,便能检索出相应的数据。
- /**
- * @desc 按时间归档函数实现
- * @author mengdejun
- * @param array $arrData 传入需要归档类所需参数
- */
- if(!function_exists("archives_document")){
- function archives_document($arrData){
- $rv=array();
- foreach($array as $index=>$value){
- $archivesTime=date("Y-m",$value['a_uptime']);
- $rv[$archivesTime][]=$value;
- //$rv[$archivesTime]+=1;
- }
- return $rv;
- }
- }
以上代码既能实现归档功能,不过需要注意的是传入数据必须包含需要归档函数的时间戳,至于命名什么的,自己看着办。 解析时需要用到php自带函数mktime来计算指定时间的起始时间戳。
- mktime(hour,minute,second,month,day,year,is_dst)
如何使用在这里就不多废话了,具体可以查看以上面的函数为例,假设访问地址为:http://host/archives.php?time=2012-04
- $time=$_GET['time'];
- $arrTime=explode("-",$time);
- $btime = mktime(0,0,0,$arrTime[1],1,$arrTime[0]);//取出当前月第一天开始时间戳
- $etime = mktime(23,59,59,$arrTime[1],date("t"),$arrTime[0]);//取出当前月最后一天结束时间戳
- //后面的程序就大家自由发挥了,SQL查询啥的就不废话了。