1

JSONで次のような多次元PHP配列があります。

array = [{
          "id":"1",
          "key":"Ferrari",
          "type":"car"},
         {
          "id":"1",
          "key":"Red",
          "type":"color"},
         {
          "id":"73",
          "key":"Yellow",
          "type":"color"
         }]

実際には検索結果なので、IDが同じ場合の結果を動的に結合したいと思います。つまり、新しい配列は次のようになります。

    array = [{
          "id":"1",
          "key":"Red Ferrari",
          "type":"keyword"}, 
         {
          "id":"73",
          "key":"Yellow",
          "type":"color"
         }]

私は多くのPHP関数を見てきましたが、多次元配列では機能が制限されています。どんな提案でも大歓迎です:)

よろしく
アンドレアス

4

1 に答える 1

1

あなたが言うように特定のことをするための基本的な機能はありません。したがって、次のようなものを作成できます。

print_r(my_array_merge($data));
function my_array_merge($data)
{
    // sort all records by id to merge them later
    $data_by_id = array();
    foreach ($data as $item)
    {
        if (!isset($data_by_id[ $item['id'] ])) {
            $data_by_id[ $item['id'] ] = array();
        }
        $data_by_id[ $item['id'] ][] = $item;
    }
    // merge records with same id
    $return = array();
    foreach ($data_by_id as $id => $items)
    {
        foreach ($items as $item)
        {
            if (!isset($return[ $id ])) {
                $return[ $id ] = $item;
            } else {
                $return[ $id ]['key'] .= ' ' . $item['key'];
                $return[ $id ]['type'] = 'keyword'; // I don't really get what you mean by 'keyword'
            }
        }
    }
    // reset keys before return
    return array_values($return);
}
于 2013-02-10T13:36:20.230 に答える