講解php擷取指定日期的相關內容

來源:互聯網
上載者:User
因工作需要,需要擷取周四開始一周的開始結束日期,而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);}?>

執行個體:測試分別以周一至周日為開始計算日期的一周開始及結束時間

<?php$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-30date:2016-04-27 week start:1 range:2016-04-25, 2016-05-01date:2016-04-27 week start:2 range:2016-04-26, 2016-05-02date:2016-04-27 week start:3 range:2016-04-27, 2016-05-03date:2016-04-27 week start:4 range:2016-04-21, 2016-04-27date:2016-04-27 week start:5 range:2016-04-22, 2016-04-28date:2016-04-27 week start:6 range:2016-04-23, 2016-04-29

本文講解了php擷取指定日期的相關內容,更多相關知識請關注php中文網。

相關推薦:

詳解PHP產生唯一RequestID類

如何通過MySQL查看資料庫表容量大小

關於php str_getcsv把字串解析為數組的使用方法的講解

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.