PHP获取一年中的每星期的开始日期和结束日期

开发 后端 前端
项目中需要做个提交周报的功能,需要知道指定周数的开始日期和结束日期,以便处理其他业务。以下是一段通过PHP来获取一年中的每星期的开始日期和结束日期的代码,与大家分享。

以下是一段通过PHP来获取一年中的每星期的开始日期和结束日期的代码。

  1. function get_week($year) {   
  2.     $year_start = $year . "-01-01";   
  3.     $year_end = $year . "-12-31";   
  4.     $startday = strtotime($year_start);   
  5.     if (intval(date('N'$startday)) != '1') {   
  6.         $startday = strtotime("next monday"strtotime($year_start)); //获取年第一周的日期   
  7.     }   
  8.     $year_mondy = date("Y-m-d"$startday); //获取年第一周的日期   
  9.    
  10.     $endday = strtotime($year_end);   
  11.     if (intval(date('W'$endday)) == '7') {   
  12.         $endday = strtotime("last sunday"strtotime($year_end));   
  13.     }   
  14.    
  15.     $num = intval(date('W'$endday));   
  16.     for ($i = 1; $i <= $num$i++) {   
  17.         $j = $i -1;   
  18.         $start_date = date("Y-m-d"strtotime("$year_mondy $j week "));   
  19.    
  20.         $end_day = date("Y-m-d"strtotime("$start_date +6 day"));   
  21.    
  22.         $week_array[$i] = array (   
  23.             str_replace("-",   
  24.             ".",   
  25.             $start_date   
  26.         ), str_replace("-""."$end_day));   
  27.     }   
  28.     return $week_array;   
  29. }  

函数get_week()通过传入参数$year年份,获取当年第一天和最后一天所在的周数,计算第一周的日期,通过循环获取每一周的第一天和最后一天的日期。最后返回是一个数组。

想得到指定周数的开始日期和结束日期,比如2011年第18周的开始日期和结束日期,代码如下:

  1. $weeks = get_week(2011);   
  2. echo '第18周开始日期:'.$weeks[18][0].'';   
  3. echo '第18周结束日期:'.$weeks[18][1];  

最后输出结果:

  1. 第18周开始日期:2011.05.02   
  2. 第18周结束日期:2011.05.08  

原文链接:http://www.helloweba.com/view-blog-125.html

【编辑推荐】

  1. 为什么说PHP是个集中营
  2. 有图有真相 PHP代码源被黑了
  3. 优秀的PHP开发者是怎样炼成的?
  4. PHP开发者常犯的10个MySQL错误
  5. 通过JavaScript或PHP检测Android设备
责任编辑:陈贻新 来源: helloweba.com
相关推荐

2009-11-17 11:39:57

PHP日期格式

2011-10-10 17:08:31

数据库SQL Server

2009-08-04 17:52:21

C#日期函数

2021-01-14 11:39:05

云计算

2012-01-16 09:21:38

编程语言

2022-03-15 13:22:19

Python日期命令

2021-05-20 06:09:02

安卓间谍软件智能手机

2023-01-06 09:02:55

CIOCEO运营

2009-11-17 11:14:14

PHP日期函数

2010-09-14 16:31:24

sqlserver日期

2024-03-12 11:36:50

MySQL数据库函数

2021-12-09 10:35:20

SQL

2009-06-12 10:34:40

Java Date

2009-03-10 10:45:51

PHP5函数实例

2010-10-09 14:42:38

MySQL获取时间

2010-04-27 16:53:53

Windows 7日期栏

2010-08-25 13:46:00

DB2函数日期

2009-02-24 16:17:41

日期时间函数

2010-04-29 12:23:58

Oracle 获取系统

2009-11-17 10:28:43

PHP星期几获取
点赞
收藏

51CTO技术栈公众号