在PHP中循环特定日期(交叉月份)

时间:2013-09-04 23:39:48

标签: php date time

我正在开发一个每周生成报告的项目,所以如果今天的日期是“2013/09/05”,那么代码必须弄清楚七天前的日期是什么,即“2013/08” / 29“,考虑到有些月份比其他月份长。

然后我想针对数据库运行日期以查找匹配...

这是我到目前为止所做的,但它不起作用。

  // Start date
        $text = explode('/', $date); //2013/09/05
        $day = $text[2];
        $month = $text[1];
        $year = $text[0];
        $past_day = $day - 7; //-2


  // determine if $past_day is negative 
if ($past_day < 0){

    $month = $month - 1; //08
    $var = $day - 0; //2
    $num = cal_days_in_month(CAL_GREGORIAN, $month, $year);
    $var = ($num - $var); // 29
    $start_date = $year."/".$month."/".$var;

}else{
    $start_date = $year."/".$month."/".$past_day;
}

非常感谢你们!

1 个答案:

答案 0 :(得分:1)

试试这个:)

$date = "2013/09/05";
// Start date
    $text = explode('/', $date); //2013/09/05
    $day = $text[2];
    $month = $text[1];
    $year = $text[0];
    $past_day = $day - 7; //-2


// determine if $past_day is negative 
if ($past_day < 0){

$month = $month - 1; //08

$var = ($past_day)*-1; //2
$num = cal_days_in_month(CAL_GREGORIAN, $month, $year);
$var = ($num - $var); // 29
$start_date = $year."/".$month."/".$var;

}else{
$start_date = $year."/".$month."/".$past_day;
}