获取指定日期之间的各个周和月

日志格式化类 Date.class.php

<?php
class Datefmt{

    function __construct() {}
    /**
     * 根据指定日期获取所在周的起始时间和结束时间
     */
    public function get_weekinfo_by_date($date) {
        $idx = strftime("%u", strtotime($date));
        $mon_idx = $idx - 1;
        $sun_idx = $idx - 7;
        return array(
            ‘week_start_day‘ => strftime(‘%Y-%m-%d‘, strtotime($date) - $mon_idx * 86400),
            ‘week_end_day‘ => strftime(‘%Y-%m-%d‘, strtotime($date) - $sun_idx * 86400),
            );
    }
    /**
     * 根据指定日期获取所在月的起始时间和结束时间
     */
    public function get_monthinfo_by_date($date){
        $ret = array();
        $timestamp = strtotime($date);
        $mdays = date(‘t‘, $timestamp);
        return array(
            ‘month_start_day‘ => date(‘Y-m-1‘, $timestamp),
            ‘month_end_day‘ => date(‘Y-m-‘.$mdays, $timestamp)
            );
    }
    /**
     * 获取指定日期之间的各个周
     */
    public function get_weeks($sdate, $edate) {
        $range_arr = array();
        // 检查日期有效性
        $this->check_date(array($sdate, $edate));
        // 计算各个周的起始时间
        do {
            $weekinfo = $this->get_weekinfo_by_date($sdate);
            $end_day = $weekinfo[‘week_end_day‘];
            
            $start = $this->substr_date($weekinfo[‘week_start_day‘]);
            $end = $this->substr_date($weekinfo[‘week_end_day‘]);
            $range = "{$start} ~ {$end}";
            $range_arr[] = $range;
            
            $sdate = date(‘Y-m-d‘, strtotime($sdate)+7*86400);
        }while($end_day < $edate);
        return $range_arr;
    }
    /**
    * 获取指定日期之间的各个月
    */
    public function get_months($sdate, $edate) {
        $range_arr = array();
        do {
            $monthinfo = $this->get_monthinfo_by_date($sdate);
            $end_day = $monthinfo[‘month_end_day‘];
            
            $start = $this->substr_date($monthinfo[‘month_start_day‘]);
            $end = $this->substr_date($monthinfo[‘month_end_day‘]);
            $range = "{$start} ~ {$end}";
            $range_arr[] = $range;
            
            $sdate = date(‘Y-m-d‘, strtotime($sdate.‘+1 month‘));
        }while($end_day < $edate);
        return $range_arr;
    }
    /**
     * 截取日期中的月份和日
     * @param string $date
     * @return string $date
     */
    public function substr_date($date) {
        if ( ! $date) return FALSE;
        return date(‘m-d‘, strtotime($date));
    }
    /**
    * 检查日期的有效性 YYYY-mm-dd
    * @param array $date_arr
    * @return boolean
    */
    public function check_date($date_arr) {
        $invalid_date_arr = array();
        foreach ($date_arr as $row) {
            $timestamp = strtotime($row);
            $standard = date(‘Y-m-d‘, $timestamp);
            if ($standard != $row) $invalid_date_arr[] = $row;
        }
        if ( ! empty($invalid_date_arr)) {
            die("invalid date -> ".print_r($invalid_date_arr, TRUE));
        }
    } 
}

类文件的使用

<?php
    require_once "Datefmt.class.php";
    
    $datefmt = new Datefmt();
    // 输出11月1日和30日之间的各周
    var_dump($datefmt->get_weeks(‘2014-11-05‘, ‘2014-11-29‘));
    /*结果为
    array(4) {
      [0]=>
      string(13) "11-03 ~ 11-09"
      [1]=>
      string(13) "11-10 ~ 11-16"
      [2]=>
      string(13) "11-17 ~ 11-23"
      [3]=>
      string(13) "11-24 ~ 11-30"
    }
    */
    // 输出2月1日和11月30日
    var_dump($datefmt->get_months(‘2014-02-03‘, ‘2014-11-29‘));
    /*结果为
    array(10) {
      [0]=>
      string(13) "02-01 ~ 02-28"
      [1]=>
      string(13) "03-01 ~ 03-31"
      [2]=>
      string(13) "04-01 ~ 04-30"
      [3]=>
      string(13) "05-01 ~ 05-31"
      [4]=>
      string(13) "06-01 ~ 06-30"
      [5]=>
      string(13) "07-01 ~ 07-31"
      [6]=>
      string(13) "08-01 ~ 08-31"
      [7]=>
      string(13) "09-01 ~ 09-30"
      [8]=>
      string(13) "10-01 ~ 10-31"
      [9]=>
      string(13) "11-01 ~ 11-30"
    }
    */
时间: 2024-09-30 23:27:49

获取指定日期之间的各个周和月的相关文章

Java 获取指定日期的方法总结 -转

格式化日期 String-->Date  或者 Data-->String SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");    Date  date = sdf.parse("2009-11-04");//String-->Date String  sdate  = sdf.format(date );// Data-->String ==================

获取指定日期的常用前后节点(月初月末周一周末等等)

原文:获取指定日期的常用前后节点(月初月末周一周末等等) 注:周节点方面是根据中国习惯,视周一为起,周日为末. /*--------------------------------- 函数:获取某日期的特定起止节点v0.01 Author:AhDung Update:201305151755 ---------------------------------*/ ALTER FUNCTION dbo.FGetSpecialDate_ahdung(@date DATE, @SpcDate VARC

php日期处理汇总,指定日期加减多少天,循环两个指定日期之间的日期

一. (1)指定日期加减多少天 (2)循环两个指定日期之间的日期 例: $start_time = '2017-07-01';$end_time = '2017-07-10'; 获取时间差 $diff= strtotime($end_time)-strtotime($start_time);$num = $diff/(24*60*60)+1; for ($i=0; $i < $num; $i++) { $selectTime = date("Y-m-d",strtotime(&q

获取指定月 获取指定日期是星期几

public static List<ExcelDateHead> getByMonth(String date){ DateFormat dateFormat=new SimpleDateFormat("yyyy-MM"); Calendar c = Calendar.getInstance(); try { c.setTime(dateFormat.parse(date)); } catch (ParseException e) { // TODO: handle ex

MSSQL 获取指定日期所在星期的第一天和最后一天日期 获取指定日期坐在月的第一天和最后一天

ufn_GetWeekFirstAndEndDay    获取指定日期所在星期的第一天和最后一天日期 ALTER FUNCTION [dbo].[ufn_GetWeekFirstAndEndDay](@tmpDate DATETIME)RETURNS  @tmpTable TABLE(            FirstDay DATETIME ,          EndDay DATETIME   )ASBEGIN    INSERT INTO @tmpTable    SELECT a.Fi

PHP获取指定日期的上个月的日期 转

PHP获取指定日期的上个月的日期 function last_month_today($time){        $last_month_time = mktime(date("G", $time), date("i", $time),                    date("s", $time), date("n", $time), 0, date("Y", $time));        $

php获取指定日期所在星期的开始时间与结束时间

function getWeekRange($date){    $ret=array();    $timestamp=strtotime($date);    $w=strftime('%u',$timestamp);    $ret['sdate']=date('Y-m-d 00:00:00',$timestamp-($w-1)*86400);    $ret['edate']=date('Y-m-d 23:59:59',$timestamp+(7-$w)*86400);    retur

获取指定日期下个月份的第一天

MS SQL Server自定义函数,指定一个日期,获取该日期的下一个月的第一天函数. 获取指定日期下个月份的第一天

获取指定日期所在月份的第一天

获取指定日期月份的第一天,你可以使用DATEADD函数,减去指定日期的月份过去了的天数,即可. CREATE FUNCTION [dbo].[udf_FirstDayOfMonth](    @Date DATE)RETURNS DATETIMEASBEGIN        RETURN CAST(DATEADD(day,1 - DAY(@Date), @Date) AS DATETIME)END CREATE FUNCTION [dbo].[udf_FirstDayOfMonth](    @