按列对二维数组的行进行分组并创建子数组[重复]

问题描述 投票:0回答:1

所以我有一个形式的多维数组(实际数组可以更长,有 500+ 个成员)

$marr = array(
    array("s_id" => 1, 1.25 , 15),
    array("s_id" => 2, 0.75 , 25),
    array("s_id" => 1, 1.15 , 7) 
); 

我试图将其分解为一个由成员数组的 s_id 值分组/索引的数组

$sarr = array(
    1 => array(
        array("s_id" => 1, 1.25 , 15),
        array("s_id" => 1, 1.15 , 7) 
    ),
    2 => array(
        array("s_id" => 2, 0.75 , 25)
    )
);

php 中是否有内置函数可以执行此操作或执行此操作的一些最佳实践方法?

php arrays multidimensional-array grouping sub-array
1个回答
4
投票

没有内置函数可以提供此结果。相反,您需要迭代数组,并检查与

s_id
值匹配的键是否已存在。如果它没有在该键处创建一个新数组。

$marr = array( array("s_id" => 1, 1.25 , 15),
               array("s_id" => 2, 0.75 , 25),
               array("s_id" => 1, 1.15 , 7) 
             ); 

// Holds the whole output
$output = array();

// Looping over the original array
foreach ($marr as $subarr) {
  // Check if the output array already has the s_id as a key
  if (!isset($output[$subarr['s_id']])) {
    // Initialize it
    $output[$subarr['s_id']] = array();
  }
  // Then append the current sub-array to the s_id array key
  $output[$subarr['s_id']][] = $subarr;
}
// Then call ksort() on the output array
// to sort the s_id keys in ascending order
ksort($output);

http://codepad.viper-7.com/SSBrAl

打印:

Array
(
    [1] => Array
        (
            [0] => Array
                (
                    [s_id] => 1
                    [0] => 1.25
                    [1] => 15
                )

            [1] => Array
                (
                    [s_id] => 1
                    [0] => 1.15
                    [1] => 7
                )

        )

    [2] => Array
        (
            [0] => Array
                (
                    [s_id] => 2
                    [0] => 0.75
                    [1] => 25
                )

        )

)
© www.soinside.com 2019 - 2024. All rights reserved.