根据相同键连接数组值

3

承接上一个问题,我有一个如下的数组:

 Array
(
    [0] => Array
        (
            [id] => 1
            [uid] => 746
            [lid] => 748
        )

   [1] => Array
        (
            [id] => 6
            [uid] => 746
            [lid] => 744
        )

   [2] => Array
        (
            [id] => 11
            [uid] => 749
            [lid] => 743
        )


)

现在我想要的是将具有相同uid的值合并,输出结果如下:
 Array
(
    [0] => Array
        (
            [id] => 1,6
            [uid] => 746
            [lid] => 748,744
        )

   [1] => Array
        (
            [id] => 11
            [uid] => 749
            [lid] => 743
        )


)

这可行吗?我不知道是否有任何相关的功能。


没有现成的函数可用。请使用循环或array_walk。 - mleko
3个回答

1

如果你将其插入到数据库中,请不要使用this因为长期来看会对你造成麻烦。无论如何,没有内置的函数可以做到这一点。你只需要一个简单的foreach循环。考虑以下示例:

$new_values = array();
$values = array(
    array('id'=> 1, 'uid' => 746, 'lid' => 748),
    array('id'=> 6, 'uid' => 746, 'lid' => 744),
    array('id'=> 11, 'uid' => 749, 'lid' => 743),
);

foreach($values as $value) {
    if(isset($new_values[$value['uid']])) {
        $temp = $new_values[$value['uid']];
        $temp['id'] .= ',' . $value['id'];
        $temp['lid'] .= ',' . $value['lid'];
        $new_values[$value['uid']] = $temp;
    } else {
        $new_values[$value['uid']] = $value;
    }
}

$new_values = array_values($new_values); // reindex keys

样例输出


1
谢谢,伙计。我不是将它插入到数据库中,更像是检索它,上面的代码允许我为每个uid列出一行数据。 - James

0
我建议构建一个uid-Array(假设您的数组在$array中):
$uid_array = array();
foreach($array as $key => $val) {
  $uid = $val["uid"];
  if(! isset($uid_array[$uid])) {
    $uid_array[$uid] = array();
  }
  if(! isset($uid_array[$uid]["id"])) {
    $uid_array[$uid]["id"] = $val["id"];
  } else {
    $uid_array[$uid]["id"].= ",".$val["id"];
  }
  if(! isset($uid_array[$uid]["lid"])) {
    $uid_array[$uid]["lid"] = $val["lid"];
  } else {
    $uid_array[$uid]["lid"].= ",".$val["lid"];
  }
}

谢谢,伙计。最终我使用了Kevin的解决方案。 - James

0

我不知道有没有一个函数可以给你想要的东西,但是这个会给你想要的:

function myArrayMerge($arr)
{
    $result = array();
    foreach($arr as $user_array)
    {
        $result[$user_array['uid']]['id'][$user_array['id']] = $user_array['id'];
        $result[$user_array['uid']]['lid'][$user_array['lid']] = $user_array['lid'];
    }

    $output = array();
    foreach($result as $uid => $result_array) {
        $output[] = array('id' => implode(',', $result_array['id']), 'uid' => $uid, 'lid' => implode(',', $result_array['lid']));
    }
    return $output;
}

谢谢,伙计。最终我使用了Kevin的解决方案。 - James

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接