作者: bjbs_270
前一段時間做了一個月報表統計用下了如題的功能,結合別人用mktime()函數我寫了一個可是後來老是出錯,郁悶極。周末抽出一點時間寫一個來用,但願能對部分村民有用。
PHP代碼:--------------------------------------------------------------------------------
/*
* 作者:心燈
* 功能:實現從指定時間向下推N個月的函數
* month($ymd,$len) $ymd時間,$len推出幾個月
* $ymd=2005-01-01;
*/
function month($ymd=,$len=12){
$month = array();
$lang = $lang."";
if($ymd){//判斷時間格式是否正確
if(!ereg("([0-9]{4})-([0-9]{1,2})-([0-9]{1,2})",$ymd)){
echo "";
exit;
}
}
if($len){
if(!ereg("[0-9]+",$len)){
echo $lang."";
exit;
}
}
for($i=0;$i<$len;$i++){
if($i==0){
$mktime = $ymd?strtotime($ymd):time();
}
$month[] = date("Y-m",$mktime);//可以根據需要來設計置你要的格式
$day = date("t",$mktime);
if($i==0)
$reday = date("d",$mktime);
else
$reday = $day;
$t1 = $mktime;
$mktime=date("Y-m-d",mktime(date("H",$t1),date("i",$t1),date("s",$t1),date("m",$t1),date("d",$t1)-$reday,date("Y",$t1)));
$mktime =strtotime($mktime);
}
return $month;
}
$month = month();
foreach($month as $key => $v){
echo $v."
";
}
?>
--------------------------------------------------------------------------------
效果如下:
2005-01
2004-12
2004-11
2004-10
2004-09
2004-08
2004-07
2004-06
2004-05
2004-04
2004-03
2004-02