频道栏目
首页 > 资讯 > php > 正文

PHP 如何获取某年第几周的开始日期和结束日期教程

18-01-12        来源:[db:作者]  
收藏   我要投稿
实例如下所示:
/**

* 获取某年第几周的开始日期和结束日期

* @param int $year

* @param int $week 第几周;

*/

public function weekday($year,$week=1){

$year_start = mktime(0,0,0,1,1,$year);

$year_end = mktime(0,0,0,12,31,$year);

// 判断第一天是否为第一周的开始

if (intval(date('W',$year_start))===1){

$start = $year_start;//把第一天做为第一周的开始

}else{

$week++;

$start = strtotime('+1 monday',$year_start);//把第一个周一作为开始

}

// 第几周的开始时间

if ($week===1){

$weekday['start'] = $start;

}else{

$weekday['start'] = strtotime('+'.($week-0).' monday',$start);

}

// 第几周的结束时间

$weekday['end'] = strtotime('+1 sunday',$weekday['start']);

if (date('Y',$weekday['end'])!=$year){

$weekday['end'] = $year_end;

}

return $weekday;

}

/**

* 计算一年有多少周,每周从星期一开始,

* 如果最后一天在周四后(包括周四)算完整的一周,否则不计入当年的最后一周

* 如果第一天在周四前(包括周四)算完整的一周,否则不计入当年的第一周

* @param int $year

* return int

*/

public function week($year){

$year_start = mktime(0,0,0,1,1,$year);

$year_end = mktime(0,0,0,12,31,$year);

if (intval(date('W',$year_end))===1){

return date('W',strtotime('last week',$year_end));

}else{

return date('W',$year_end);

}

}

 

相关TAG标签
上一篇:Oracle数据库关闭和启动命令是什么?
下一篇:MySQL大数据量分页查询方法及其优化教程
相关文章
图文推荐

关于我们 | 联系我们 | 广告服务 | 投资合作 | 版权申明 | 在线帮助 | 网站地图 | 作品发布 | Vip技术培训 | 举报中心

版权所有: 红黑联盟--致力于做实用的IT技术学习网站