MarkJane
4/12/2017 - 7:33 AM

某月第一天与最后一天-或-某年的第一天与最后一天 获取开始日期与结束日期之间所有日期 因工作需要,需要获取周四开始一周的开始结束日期,而php没有提供获取本周开始及结束日期的方法,因此写了一个方法方便以后使用。

某月第一天与最后一天-或-某年的第一天与最后一天 获取开始日期与结束日期之间所有日期 因工作需要,需要获取周四开始一周的开始结束日期,而php没有提供获取本周开始及结束日期的方法,因此写了一个方法方便以后使用。

<?php
/**
 * 计算指定日期的一周开始及结束日期
 * @param  DateTime $date  日期
 * @param  Int      $start 周几作为一周的开始 1-6为周一~周六,0为周日,默认0
 * @retrun Array
 */
function getWeekRange($date, $start=0){

    // 将日期转时间戳
    $dt = new DateTime($date);
    $timestamp = $dt->format('U');

    // 获取日期是周几
    $day = (new DateTime('@'.$timestamp))->format('w');

    // 计算开始日期
    if($day>=$start){
        $startdate_timestamp = mktime(0,0,0,date('m',$timestamp),date('d',$timestamp)-($day-$start),date('Y',$timestamp));
    }elseif($day<$start){
        $startdate_timestamp = mktime(0,0,0,date('m',$timestamp),date('d',$timestamp)-7+$start-$day,date('Y',$timestamp));
    }

    // 结束日期=开始日期+6
    $enddate_timestamp = mktime(0,0,0,date('m',$startdate_timestamp),date('d',$startdate_timestamp)+6,date('Y',$startdate_timestamp));

    $startdate = (new DateTime('@'.$startdate_timestamp))->format('Y-m-d');
    $enddate = (new DateTime('@'.$enddate_timestamp))->format('Y-m-d');

    return array($startdate, $enddate);
}
//实例:测试分别以周一至周日为开始计算日期的一周开始及结束时间

$date = '2016-04-27';
for($start=0; $start<=6; $start++){
    list($startdate, $enddate) = getWeekRange($date, $start);
    echo 'date:'.$date.' week start:'.$start.' range:'.$startdate.', '.$enddate.'<br>';
}
/*
输出:
date:2016-04-27 week start:0 range:2016-04-24, 2016-04-30
date:2016-04-27 week start:1 range:2016-04-25, 2016-05-01
date:2016-04-27 week start:2 range:2016-04-26, 2016-05-02
date:2016-04-27 week start:3 range:2016-04-27, 2016-05-03
date:2016-04-27 week start:4 range:2016-04-21, 2016-04-27
date:2016-04-27 week start:5 range:2016-04-22, 2016-04-28
date:2016-04-27 week start:6 range:2016-04-23, 2016-04-29
*/
<?php
//某年的第一天
$year=date("Y",time());
$first=$year."-01-01";
$end=$year."-12-31";

//使用函数及数组来获取当月第一天及最后一天,比较实用
function getthemonth($date){
   $firstday = date('Y-m-01', strtotime($date));
   $lastday = date('Y-m-d', strtotime("$firstday +1 month -1 day"));
   return array($firstday,$lastday);
}

$today = date("Y-m-d");
$day=getthemonth($today);
echo "当月的第一天: ".$day[0]." 当月的最后一天: ".$day[1];
echo "<br/>";

<?php
/*因项目需求,需要获取指定日期段内的数据按每日进行处理。
例如需要对2016-06-01至2016-06-05日期段内,每一天的数据进行处理。首先需要获取这个日期段内每一天日期,再循环执行处理。
*/

$date = array('2016-06-01','2016-06-02','2016-06-03','2016-06-04','2016-06-05');
foreach($date as $d){
    // 执行处理
}

/*
如果日期段跨度大(2015-09-01至2016-06-30),并且有跨年,跨月(闰月)的情况,人手创建日期数组太费时间且不合理。
因此写了以下方法,可以获取指定日期段内每一天的日期,代码如下:
*/
/**
 * 获取指定日期段内每一天的日期
 * @param  Date  $startdate 开始日期
 * @param  Date  $enddate   结束日期
 * @return Array
 */
function getDateFromRange($startdate, $enddate){

    $stimestamp = strtotime($startdate);
    $etimestamp = strtotime($enddate);

    // 计算日期段内有多少天
    $days = ($etimestamp-$stimestamp)/86400+1;

    // 保存每天日期
    $date = array();

    for($i=0; $i<$days; $i++){
        $date[] = date('Y-m-d', $stimestamp+(86400*$i));
    }

    return $date;
}

// demo
$date = getDateFromRange('2016-02-25','2016-03-05');
print_r($date);

/*输出:

Array
(
    [0] => 2016-02-25
    [1] => 2016-02-26
    [2] => 2016-02-27
    [3] => 2016-02-28
    [4] => 2016-02-29
    [5] => 2016-03-01
    [6] => 2016-03-02
    [7] => 2016-03-03
    [8] => 2016-03-04
    [9] => 2016-03-05
)*/