将重复元素组合为多维数组中的数组

时间:2013-04-02 14:06:20

标签: php arrays

我想知道在使用多媒体数组时,如果某个键是相同的,如果某个键是相同的,有没有办法将其他键的内容组合到自己的数组中?

这样的事情:

// name is the same in both arrays
array(
    array(
        'name' => 'Pepsi',
        'store' => 'Over here',
        'number' => '1234567'
    ),
    array(
        'name' => 'Pepsi',
        'store' => 'Over here',
        'number' => '5556734'
    )
)

这样的事情

array(
    array(
        'name' => 'Pepsi',
        'store' => array('Over here', 'Over here'),
        'number' => array('1234567', '5556734')
    )
)

定义键是检查name元素是否与其他数组相同。

3 个答案:

答案 0 :(得分:1)

您可以尝试这样的功能。

function mergeByKey($array,$key){
  $tmp_array = array();
  foreach ( $array as $k => $row ) {
    $merged = false;
    foreach ($tmp_array as $k2 => $tmp_row){
       if ($row[$key] == $tmp_row[$key]){
          foreach ( $row as $k3 => $value ) {
            if ($k3 == $key) continue;
            $tmp_array[$k2][$k3][] = $value;
            $merged = true;
          }
       }
       if ($merged) break;
    }
    if (!$merged) {
       $new_row = array();
       foreach ( $row as $k4 => $value ) {
         if ($k4 == $key) $new_row[$k4] = $value;
         else $new_row[$k4] = array($value);
       }
       $tmp_array[] = $new_row;
    }
  }
  foreach ( $tmp_array as $t => $row ) {
    foreach ( $row as $t2 => $value ) {
      if ( count($value) == 1 && $t2 != $key ) $tmp_array[$t][$t2] = $value[0];
    }
  }
  return $tmp_array;
}

将数组作为第一个参数传递,将键作为第二个参数传递。 我正在引用你的数组结构

编辑:错过了一篇

edited2:如果resultin数组包含带有一个字符串的元素,则返回一个字符串而不是一个带有一个元素的数组

demo

答案 1 :(得分:1)

此函数使用给定的字段名称作为分组标识符,并将所有其他字段转换为数组。

请注意,单个出现的字段名称将产生具有其他字段的单个元素的数组。我不确定这是否是一个令人满意的特质,但只是确保你知道; - )

$arr = array(
    array(
        'name' => 'Pepsi',
        'store' => 'Over here',
        'number' => '1234567'
    ),
    array(
        'name' => 'Pepsi',
        'store' => 'Over here',
        'number' => '5556734'
    )
);

function mergeArray($array, $column)
{
    $res = array();

    foreach ($array as $item) {
        foreach ($item as $key => $value) {
            if ($key === $column) {
                $res[$column][$key] = $value;
            } else {
                $res[$column][$key][] = $value;
            }
        }
    }
    return array_values($res);
}

print_r(mergeArray($arr, 'name'));

Demo

答案 2 :(得分:0)

感谢Gianni Lovece的回答,但我能够根据这个问题开发一个更简单的解决方案。只需插入$result_arr即可浏览并使用$key作为基础,它会立即输出一个多维数组,其中包含重复元素的非重复值(参见下面的示例)。

function multiarray_merge($result_arr, $key){

    foreach($result_arr as $val){
        $item = $val[$key];     
        foreach($val as $k=>$v){
            $arr[$item][$k][] = $v;
        }
    }

    // Combine unique entries into a single array
    // and non-unique entries into a single element
    foreach($arr as $key=>$val){
        foreach($val as $k=>$v){
            $field = array_unique($v);
            if(count($field) == 1){
                $field = array_values($field);
                $field = $field[0];
                $arr[$key][$k] = $field;
            } else {
                $arr[$key][$k] = $field;
            }
        }
    }
    return $arr;
}

例如,在此问题的示例数组中,运行multiarray_merge($mysample, 'name')会返回

array(
    'Pepsi' => array(
        'name' => 'Pepsi',
        'store' => 'Over here', // String: Not an array since values are not unique
        'number' => array('1234567', '5556734') // Array: Saved as array since values are unique
    )
);