Heim >Backend-Entwicklung >PHP-Tutorial >PHP怎么往间隔数组中添加数据

PHP怎么往间隔数组中添加数据

WBOY
WBOYOriginal
2016-07-06 13:53:331037Durchsuche

现有一数组如下:
[site003] => Array

<code>    (
        [0] => Array
            (
                [key] => site003
                [riqi] => 2016-06-14
                [shijian] => 00
                [num] => 1
            )

        [1] => Array
            (
                [key] => site003
                [riqi] => 2016-06-14
                [shijian] => 04
                [num] => 2
            )

        [2] => Array
            (
                [key] => site003
                [riqi] => 2016-06-14
                [shijian] => 07
                [num] => 6
            )

    )</code>

由于时间shijian字段00到-04点中间没有01,02,03时间点,所以想对01,02,03时间点组装数据的num字段补充为0,
后者04-07中间时间点05,06也对num的时间点补充数组为0
麻烦各路高手指点迷津!小弟在此谢谢!

回复内容:

现有一数组如下:
[site003] => Array

<code>    (
        [0] => Array
            (
                [key] => site003
                [riqi] => 2016-06-14
                [shijian] => 00
                [num] => 1
            )

        [1] => Array
            (
                [key] => site003
                [riqi] => 2016-06-14
                [shijian] => 04
                [num] => 2
            )

        [2] => Array
            (
                [key] => site003
                [riqi] => 2016-06-14
                [shijian] => 07
                [num] => 6
            )

    )</code>

由于时间shijian字段00到-04点中间没有01,02,03时间点,所以想对01,02,03时间点组装数据的num字段补充为0,
后者04-07中间时间点05,06也对num的时间点补充数组为0
麻烦各路高手指点迷津!小弟在此谢谢!

首先你需要确定你是否需要插入相关数据以及你插入的数据的方案,如果你不能确定中间缺失的shijian字段的始末的话,需要遍历这个数组去确定,然后将没有的字段加进去,然后用usort进行排序。
也可以在插入的时候决定你插入的位置,但是由于你插入会影响你数组的下标,所以还是上面第一个方法比较方便。
参考代码

<code class="PHP"><?php $max_shijian = date("H");

// 填充主方法
$fill_date = function ($input,$key) use($max_shijian) {
  $hours = range(0,$max_shijian);
  $riqi = null;
  // 筛选出不存在的时间
  // http://php.net/manual/zh/function.array-map.php
  array_map(function(&$item,$key) use(&$hours,&$riqi){
    empty($riqi) and $riqi = $item['riqi'];
    unset($hours[intval($item['shijian'])]);
  },$input);
  // 填充不存在的时间
  foreach ($hours as $hour) {
    $input[] =   [
        'key' => $key,
        'riqi'  => $riqi,
        'shijian' => getFullHour($hour),
        'num' => 0,
      ];
  }
  // 排序
  // http://php.net/manual/zh/function.usort.php
  usort($input,function($a,$b){
    return (intval($a['shijian'])<intval return function getfullhour json_decode foreach as> $value) {
  $data[$key] = call_user_func($fill_date,$value,$key);
}
print_r($data);


?></intval></code>

array_map
usort

我说说我理解的思路,首先要先取你这个数组中shijian字段的最大值,然后根据最大值循环填充。

你试下以下方法,
主要采用的思路是:
1.先从给定的数组中过滤出最大的shijian值,同时存储已经存在的时间值,
2.添加小于最大shijian值且不存在数组中的数据

<code>    $srcArray = array
    (array(
                'key'  => 'site003',
                'riqi'=> '2016-06-14',
                'shijian' => 00,
                'num' => 1,
            )
                 ,array
            (
                'key' => 'site003',
                'riqi' => '2016-06-14',
                'shijian' => 02,
                'num'=> 2
            )
     ,array
            (
                'key' => 'site003',
                'riqi' => '2016-06-14',
                'shijian' => 04,
                'num'=> 2
            )
    );

    $data=array(-1);
    foreach($srcArray as $key=>$innerArray){
        array_push($data,$innerArray['shijian']);
        if($innerArray['shijian'] > $data[0]){
            $data[0] = intval($innerArray['shijian']);
        }
    }
    print_r($data);
    for($index = 0;$index 'site003',
                'riqi'=> '2016-06-14',
                'shijian' => $index 0,
            );
            array_push($srcArray,$temp);
        }
    }
    print_r($srcArray);</code>
Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn