今日开发本站需要用到按时间归档文章的功能,即按文档发布时间将文章文类,以实现检索和统计功能,于是自己写了一个, 现分享给大家,相信大家工作和学习中有可能会用到,实现原理很简单,即取出文章发布时间戳的年月(年月日也可以,自 决定),生成相应的统计数据,调用时只需要知道该数组元素所标识时间的起始时间戳,便能检索出相应的数据。

 
  1. /**  
  2.  * @desc 按时间归档函数实现  
  3.  * @author mengdejun  
  4.  * @param array $arrData 传入需要归档类所需参数  
  5.  */ 
  6. if(!function_exists("archives_document")){  
  7.     function archives_document($arrData){  
  8.         $rv=array();  
  9.         foreach($array as $index=>$value){  
  10.             $archivesTime=date("Y-m",$value['a_uptime']);  
  11.                 $rv[$archivesTime][]=$value;  
  12.                 //$rv[$archivesTime]+=1;  
  13.         }  
  14.         return $rv;  
  15.     }  
  16. }  

 

以上代码既能实现归档功能,不过需要注意的是传入数据必须包含需要归档函数的时间戳,至于命名什么的,自己看着办。 解析时需要用到php自带函数mktime来计算指定时间的起始时间戳。

 
  1. mktime(hour,minute,second,month,day,year,is_dst) 

如何使用在这里就不多废话了,具体可以查看以上面的函数为例,假设访问地址为:http://host/archives.php?time=2012-04

 
  1. $time=$_GET['time'];  
  2. $arrTime=explode("-",$time);  
  3. $btime = mktime(0,0,0,$arrTime[1],1,$arrTime[0]);//取出当前月第一天开始时间戳  
  4. $etime = mktime(23,59,59,$arrTime[1],date("t"),$arrTime[0]);//取出当前月最后一天结束时间戳  
  5. //后面的程序就大家自由发挥了,SQL查询啥的就不废话了。