填补数据缺失的天数

时间:2012-07-02 22:01:06

标签: php time

我有一个看起来像这样的数组:

$data = array(
    array('timestamp' => 1312776000, 'something' => 100), // data for 08.08.2011
    array('timestamp' => 1312862400, 'something' => 120), // data for 09.08.2011
    //  ????????                                          // data for 10.08.2011
    array('timestamp' => 1313035200, 'something' => 160), // data for 11.08.2011
    array('timestamp' => 1313121600, 'something' => 180), // data for 12.08.2011
    array('timestamp' => 1313208000, 'something' => 200), // data for 13.08.2011
    //  ????????                                          // data for 14.08.2011
    //  ????????                                          // data for 15.08.2011
    //  ????????                                          // data for 16.08.2011
    //  ????????                                          // data for 17.08.2011
    array('timestamp' => 1313640000, 'something' => 300), // data for 18.08.2011
);

如何识别“洞”并用'some'=>填充子阵列0?正如你所看到的,“漏洞”可能非常大,这就是我自己无法解决这个问题的原因 - 我的算法只能填充微小的“漏洞”(如10.08.2011,但不是14.08.2011 - > 17.08 0.2011)。

3 个答案:

答案 0 :(得分:0)

您的数据似乎已排序,我猜您想要每天获得一个值。我采用了编写新输出数组的懒惰方法,但您可以将值附加到现有数组,然后在结尾按时间戳排序。

我会做这样的事情:

$outArray = array();
$lastTime = $data[0]['timestamp'] - 86400;
foreach($data as $values) {
    $dayDelta = ($values['timestamp'] - $lastTime)/86400;
    if ( $dayDelta != 1) {
        for ($i = $dayDelta-1; $i--; $i>0) {
            $pastDate = $values['timestamp'] - $i * 86400;
            $outArray[] = array('timestamp'=>$pastDate, 'something'=>0);
        }
    }
    $outArray[]=$values;
    $lastTime = $values['timestamp'];
}

答案 1 :(得分:0)

另一种需要考虑的方法:

$previous_d = false;
for($di=0; isset($data[$di]); $di++) {
    $d = $data[$di];
    if($previous_d && ($d['timestamp']-$previous_d['timestamp'])>86400) {
        $new_d = array('timestamp'=>$previous_d['timestamp']+86400,'something'=>0);
        array_splice($data,$di,0,array($new_d));
        $di--;
    }
    $previous_d = $d;
}

答案 2 :(得分:0)

可以这样做:

$new = array();
$prev = reset($data);
while ($record = reset($data)) {
    while ($prev['timestamp'] < $record['timestamp']-86400) {
        $prev['timestamp'] += 86400;
        $prev['something'] = 0;
        $new[] = $prev;
    }
    $new[] = $record;
    $prev = $record;
    unset($data[key($data)]);
}
$data = $new;

echo '<pre>';
var_export($data);
echo '</pre>';