如何通过提供当前数据
来获得接下来的10个星期日以下是我的代码,但它是在日期范围之间,我只是想给出开始日期,并从开始日期开始接下来的10个星期日(没有结束日期)。
$allweeks=array();
$startDate = date('Y-m-d');
$date = new DateTime($startDate);
$interval = new DateInterval('P2M');
$date->add($interval);
$endDate=$date->format('Y-m-d');
for ($i = strtotime($startDate); $i <= strtotime($endDate); $i = strtotime('+1 day', $i)) {
if (date('N', $i) == 1)
$allweeks[]= date('n-j', $i);
}
foreach($allweeks as $wks)
{
$weeks=explode('-', $wks);
echo '=Week of '.$weeks[0]."/".$weeks[1];
}
答案 0 :(得分:0)
您可以使用DateTime
类或strtotime
函数:
看看下面的代码:
使用DateTime
类
$date = '2016-04-05';
$date = new DateTime($date);
// Modify the date it contains
for($i =0; $i < 10; $i++){
$date->modify('next sunday');
// Output
echo $date->format('l : Y-m-d');
echo '<br />';
}
使用strtotime
功能
$date = '2016-04-05';
// Modify the date it contains
for($i =0; $i < 10; $i++){
$date = date('Y-m-d', strtotime('next sunday', strtotime($date)));
echo date('l : Y-m-d', strtotime($date));
echo '<br />';
}
<强>输出强>
Sunday : 2016-04-10
Sunday : 2016-04-17
Sunday : 2016-04-24
Sunday : 2016-05-01
Sunday : 2016-05-08
Sunday : 2016-05-15
Sunday : 2016-05-22
Sunday : 2016-05-29
Sunday : 2016-06-05
Sunday : 2016-06-12