Php获取按月分组的时间戳值

时间:2017-08-23 10:38:23

标签: php

假设我有

$time1 = 1492894800 //23/04/2017
$time2 = 1503521999  //23/08/2017

我想将时间戳按月分组,以便

get timestamp with rangess between months preserving first and last month of $time1 and $time2 such that i should have

 1 23/04/2017 to 30/04/2017
 2 01/05/2017 - 31/05/2017
 ....... //continue full months and lastly

 01/08/2017 - 23/08/2017

我试过了

$timearrays = $this->getMontTimestampRanges($time1, $time2); 

public function getMontTimestampRanges($ts1, $ts2){

    $start    = (new DateTime(date("Y-m-d", $ts1)));
    $end      = (new DateTime(date("Y-m-d", $ts2)));

    $interval = DateInterval::createFromDateString('1 day');
    $period   = new DatePeriod($start, $interval, $end);

    $timestamps = [];
    foreach ($period as $dt) {
      //am stuck here on how to group based on the months      

      ..push to array
    }

    return $timestamps;

}

所以最终数组我希望它的形式为:

$timestamps = [
    0=>["from":, "to":  ] //first month(april)
    1=>[ ] //second month may 
 ]

我该怎么做?

2 个答案:

答案 0 :(得分:1)

我编辑了你的代码

试试这个:

<?php
$time1 = 1492894800 ;//23/04/2017
$time2 = 1503521999;  //23/08/2017
$timearrays = getMontTimestampRanges($time1, $time2); 
var_dump( $timearrays);
 function getMontTimestampRanges($ts1, $ts2){

    $start    = new DateTime(date("Y-m-d", $ts1));
    $end      = new DateTime(date("Y-m-d", $ts2));

    $interval = DateInterval::createFromDateString('1 month');
    $period   = new DatePeriod($start, $interval, $end);

    $timestamps = [];

    $startM = $period->getStartDate()->format('m');
    $endM  = $period->getEndDate()->format('m');

    foreach ($period as $dt) {
      //am stuck here on how to group based on the months      
        //start
        if($startM == $dt->format('m'))
        {
           $timestamps[] = array('start'=>$start->format('Y-m-d'),'end'=>$dt->format('Y-m-t'));
        }
        elseif($endM == $dt->format('m'))
        {
            $timestamps[] = array('start'=>$dt->format('Y-m').'-01','end'=>$end->format('Y-m-d') );
        }
        else
        {
            $timestamps[] = array('start'=>$dt->format('Y-m').'-01','end'=>$dt->format('Y-m-t'));
        }


    }

    return $timestamps;

}

http://sandbox.onlinephpfunctions.com/code/8527e45427fd0114f1e058fffc1885e460807a0a

希望它有所帮助。

答案 1 :(得分:1)

在澄清您对我的上一个答案的查询后,我决定删除我的答案并发布新答案。

$start = 1492894800; //23/04/2017
$end = 1503521999;  //23/08/2017

$steps = date('Ym', $end) - date('Ym', $start);

$timestamps = array();
for($i = 0; $i <= $steps; $i++) {
    $base = strtotime("+{$i} months", $start);

    $timestamps[] = array(
        'from' => $i == 0 ? date('Y-m-d', $start) : date('Y-m-01', $base),
        'to' => $i == $steps ? date('Y-m-d', $end) : date('Y-m-t', $base)
    );

//  If we want timestamps   
//  $timestamps[] = array(
//      'from' => strtotime(date('Y-m-01', $base)),
//      'to' => strtotime(date('Y-m-t', $base))
//  );
}

print_r($timestamps);

Ideone link