0

我正在编写一个程序代码来显示两个日期之间的周数。我还想显示周数之间的日期。我已经根据堆栈溢出的示例代码编写了以下代码。(这里&&这里

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--Start-07Apr2013-End-13Apr2013

周数:14--Start-07Apr2013-End-13Apr2013

周数:15--Start-14Apr2013-End-20Apr2013

周数:16--Start-21Apr2013-End-27Apr2013

周数:17--Start-28Apr2013-End-04May2013

第 14 周从 2013 年 3 月 31 日到 2013 年 4 月 6 日。我无法弄清楚问题是什么。必须感谢任何帮助!

4

2 回答 2

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/>";
}
于 2013-05-24T04:35:52.603 回答
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
于 2013-05-24T03:44:42.753 回答