PHP周数和开始日期和结束日期

时间:2013-05-24 02:49:22

标签: php date strtotime

我正在编写一个程序代码来显示两个日期之间的周数。我也希望显示周数之间的日期。我根据堆栈溢出的示例代码编写了以下代码。(here&& here

function getStartAndEndDate($week, $year)
{
$time = strtotime("1 January $year", time());
$day = date('w', $time);
$time += ((7*$week)+1-$day)*24*3600;
$return[0] = date('dMY', $time);
$time += 6*24*3600;
$return[1] = date('dMY', $time);
return $return;
}
$startTime = strtotime('2013-04-01');
$endTime = strtotime('2013-05-03');

$weeks = array();

while ($startTime < $endTime) 
{
$weeks[] = date('W', $startTime);
$startTime += strtotime('+1 week', 0);
}
echo count($weeks)."<br/>";
$year="2013";
foreach ($weeks as $key => $w)
{
echo "Week Number:".$w."--";
$return=getStartAndEndDate($w,$year);
$r0=$return[0];
$r1=$return[1];
echo "Start-".$r0."-End-".$r1."<br/>";
}

但输出错了。输出显示:

  

5

     

周数:14 - 开始-07Apr2013-End-13Apr2013

     

周数:14 - 开始-07Apr2013-End-13Apr2013

     

周数:15 - 开始 - 14Apr2013-End-20Apr2013

     

周数:16 - 开始-21Apr2013-End-27Apr2013

     

周数:17 - 开始-28Apr2013-End-04May2013

第14周从2013年3月31日开始到2013年6月6日。我无法弄清楚问题是什么。任何帮助必须得到赞赏!

2 个答案:

答案 0 :(得分:0)

您是否尝试使用日期检查

$startTime = strtotime('2012-12-30');
$endTime = strtotime('2013-05-03');

实际的第14周是

Week Number:14--Start-08Apr2013-End-14Apr2013

不是

14th week starts from 31Mar2013 to 6Apr2013

PHP从周一开始周 - >周日。因此,如果您使用星期日的2012-12-30,它将计算

Week Number:01--Start-07Jan2013-End-13Jan2013
Week Number:02--Start-14Jan2013-End-20Jan2013
Week Number:03--Start-21Jan2013-End-27Jan2013
Week Number:04--Start-28Jan2013-End-03Feb2013
Week Number:05--Start-04Feb2013-End-10Feb2013
Week Number:06--Start-11Feb2013-End-17Feb2013
Week Number:07--Start-18Feb2013-End-24Feb2013
Week Number:08--Start-25Feb2013-End-03Mar2013
Week Number:09--Start-04Mar2013-End-10Mar2013
Week Number:10--Start-11Mar2013-End-17Mar2013
Week Number:11--Start-18Mar2013-End-24Mar2013
Week Number:12--Start-25Mar2013-End-31Mar2013
Week Number:13--Start-01Apr2013-End-07Apr2013
Week Number:14--Start-08Apr2013-End-14Apr2013

答案 1 :(得分:0)

我已经弄明白了:

function week_start_date($wk_num, $yr, $first = 1, $format = 'F d, Y')
{
    $wk_ts  = strtotime('+' . $wk_num . ' weeks', strtotime($yr . '0101'));
    $mon_ts = strtotime('-' . date('w', $wk_ts) + $first . ' days', $wk_ts);
    return date($format, $mon_ts);
}


$year="2013";
$startDate="2012-12-30";
$endDate="2013-05-03";

$p = new DatePeriod(
        new DateTime($startDate),
        new DateInterval('P1W'),
        new DateTime($endDate)
);

foreach ($p as $k=>$w) {
    echo $k.":".$w->format('W')."<br/>";
    $w=$w->format('W');
    $sStartDate = week_start_date($w, $year);
    $sEndDate   = date('F d, Y', strtotime('+6 days', strtotime($sStartDate)));
    echo $sStartDate."&&".$sEndDate."<br/>";
}