Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/php/249.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
PHP:对数组中的项重新编号_Php_Arrays - Fatal编程技术网

PHP:对数组中的项重新编号

PHP:对数组中的项重新编号,php,arrays,Php,Arrays,我有一个数组有点像: Array ( [1] => Array ( [1] => 21 [2] => 3 [0] => Analyst ) [2] => Array ( [1] => 47 [2] => 8

我有一个数组有点像:


Array (    
        [1] => Array
            (
                [1] => 21
                [2] => 3
                [0] => Analyst
            )    
        [2] => Array
            (
                [1] => 47
                [2] => 8
                [0] => Catalysis
            )

        [3] => Array
            (
                [1] => 1
                [2] => 0
                [0] => Biomaterials 
            )

        [4] => Array
            (
                [3] => 12
                [4] => 2
                [0] => Analyst
            )

       [5] => Array
            (
                [5] => 12
                [6] => 2
                [0] => Analyst
            )
...
但是,我想用相同的[0]值对这些条目重新编号,以便最终得到


       [1] => Array
            (
                [1] => 21
                [2] => 3
                [3] => 12
                [4] => 2
                [5] => 12
                [6] => 2
                [0] => Analyst
            )
到目前为止,我已经尝试从
$results
数组中获取[0]值,方法是将它们放在自己的数组中,并说如果已经存在[3]和[4],则将[1]和[2]添加到新数组中,但不起作用

$final = array();
$jArray = array();

foreach($results as $key => $result) {
  if(!in_array($result[0],$jArray) && !empty($result[0])) {
    $jArray[$i] = $result[0];
    $i++;
  }
}



for($x = 0; $x < count($results); $x++) { 
      $k = array_search($results[$x][0],$jArray);
    if(!isset($results[$x][1])) 
      $final[$k][1] = $results[$x][1];
    if(!isset($results[$x][2])) 
      $final[$k][2] = $results[$x][2];    
    if(!isset($results[$x][3])) 
      $final[$k][3] = $results[$x][3];
   if(!isset($results[$x][4])) 
      $final[$k][4] = $results[$x][4];
    if(!isset($results[$x][5]))     
      $final[$k][5] = $results[$x][5];
    if(!isset($results[$x][6]))     
      $final[$k][6] = $results[$x][6];
}
$final=array();
$jArray=array();
foreach($results作为$key=>$result){
如果(!in_数组($result[0],$jArray)&!empty($result[0])){
$jArray[$i]=$result[0];
$i++;
}
}
对于($x=0;$x
有更简单的方法吗?

这里

$final = array();

foreach($results as $key => $result) {
  if (!in_array($result[0], array_keys( $final ) ) && !empty($result[0])) {
    $final[$result[0]] = array( $result[0] );
  }
  foreach($result as $k => $v) {
    if ($k != 0 && isset($v)) {
      $final[$result[0]][$k] = $v;
    }
  } 
}
你可以这样做

$new_arr=array();
$arkeys = array_unique(array_map(function ($v){ return $v[0];},$arr));
foreach($arr as $k=>$arr1)
{
            $new_arr[$arr1[0]][]=array_slice($arr1,0,count($arr1)-1);
}

foreach($arkeys as $v)
{
$new_arr[$v] = call_user_func_array('array_merge', $new_arr[$v]);
}
print_r($new_arr);
输出:

Array
(
    [Analyst] => Array
        (
            [0] => 21
            [1] => 3
            [2] => 12
            [3] => 2
            [4] => 12
            [5] => 2
        )

    [Catalysis] => Array
        (
            [0] => 47
            [1] => 8
        )

    [Biomaterials] => Array
        (
            [0] => 1
            [1] => 0
        )

)

如果只想按子数组的第一个元素分组,一个循环就足够了:

$result = array();

foreach ($array as $sub_arr) {
  $key = $sub_arr[0];
  unset($sub_arr[0]);
  if (!isset($result[$key])) {
    $result[$key] = array();
  }
  $result[$key] += $sub_arr;
}

只需在循环中放入第二个循环。恐怕它不起作用:我得到[]=>[Analyst]=>数组([0]=>Analyst[1]=>21[2]=>3[3]=>4[4]=>1[5]=>42[6]=>3[7]=>8]=>9]=>4[10]=>0)[生物材料==>数组([0]=>生物材料[1]=>1[2]=>0[3]=>4]=>5]=>6]=>也就是说,我不知道为什么第一个填9和10,然后只填1和2。对不起,我误解了。现在我修改了代码。很好,但我有38个不同的“主题”这可能会改变,所以我想要一个更优雅的大开关statement@ian,我已经概括了答案。请看一看。非常感谢,效果非常好。代码也非常少。Genius+1