再帰処理で平坦な連想配列をツリー化

多次元配列

概要

 閲覧数:2714  投稿日:2016-01-18  更新日:2016-01-18  

連想配列に、再帰処理をかけてツリー状の連想配列を生成
・添字に値を格納
・末端のみ値を数値として格納


コード

$tourist_spot = array(
  'a' => array('日本','東京都','台東区','浅草','浅草寺',10),
  'b' => array('日本','東京都','千代田区','大手町','首塚',5),
  'c' => array('日本','千葉県','浦安市','舞浜','ディズニーランド',10),
  'd' => array('日本','東京都','台東区','浅草','浅草演芸ホール',7),
);

$tree = array();
foreach ($tourist_spot as $spot) {
  $current = &$tree;
  foreach (array_slice($spot, 0, -1) as $segment) {
    if (!isset($current[$segment])) {
      $current[$segment] = array();
    }
    $current = &$current[$segment];
  }
  $current = current(array_slice($spot, -1));
}
unset($current);

print_r($tree);



結果

Array
(
    [日本] => Array
        (
            [東京都] => Array
                (
                    [台東区] => Array
                        (
                            [浅草] => Array
                                (
                                    [浅草寺] => 10
                                    [浅草演芸ホール] => 7
                                )

                        )

                    [千代田区] => Array
                        (
                            [大手町] => Array
                                (
                                    [首塚] => 5
                                )

                        )

                )

            [千葉県] => Array
                (
                    [浦安市] => Array
                        (
                            [舞浜] => Array
                                (
                                    [ディズニーランド] => 10
                                )

                        )

                )

        )

)



タグ


array_slice 





三次元配列の「三次元要素数」をカウント

多次元配列ソート



週間人気ページランキング / 4-21 → 4-27
順位 ページタイトル抜粋 アクセス数
1 PHPコード 28
2 Smarty(テンプレートエンジン) カテゴリー 2
2 if文には括弧を付けた方が良い | 条件分岐 2
2 session_regenerate_id | タグ毎エントリー一覧 2
2 現在のセッション名を取得、表示 | セッション 2
2 配列定数同士をarray_mergeで後ろに単純連結(キーは新たに振り直す) | 定数 2
2 array_filter | タグ毎エントリー一覧 2
2 相関係数 | 統計 2
2 2次元配列を指定キーでソートするuser定義関数 | 多次元配列(型) 2
2 多次元配列の「一次元要素数」もしくは「全次元要素数」をカウント | 多次元配列(型) 2
2 URLから、トップページ(index.html)判定 | ルーティング 2
2 gethostbyaddr / IPアドレスからホスト名を取得 | ネットワーク 関数 2
3 foreachの中でswitch文 | 配列(型) 1
3 Smarty(テンプレートエンジン) カテゴリー 1
3 2.3.4 訳者をランキングする  | 2章(集合知プログラミング) 1
3 配列のキーをランダムに取得する array_rand() | 配列(型) 1
3 アルファベット大文字を、小文字へ変換して表示 | 文字列(テキスト処理) 1
3 対象文字列の内、「最初の指定文字列以前」と「それ以降の文字列」を取得する | 文字列(テキスト処理) 1
3 ctype_alnum / 英数字だけを許可 | Ctype 文字タイプチェック(バリデーション) 1
3 setcookie | タグ毎エントリー一覧 1
2026/4/28 5:05 更新