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

多次元配列

概要

 閲覧数:2700  投稿日: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 





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

多次元配列ソート



週間人気ページランキング / 12-20 → 12-26
順位 ページタイトル抜粋 アクセス数
1 日付文字列を比較して、年月日が異なる場合は年月日を、同一年の場合は月日を返す、同一年月の場合は月日を返す。※1日を厳密に直近24時間以内で判定 | 日付および時刻関連 5
2 後ろから3文字削除 / 「18:00:00」→「18:00」 | 文字列(テキスト処理) 3
2 「半角スペースもしくは全角スペースで区切られた文字列」先頭に指定文字列を付与 | 文字列(テキスト処理) 3
3 対象文字列へ対して、一致したすべての文字列を置換する標準関数 / str_replace | 文字列(テキスト処理) 2
3 配列の要素に特定の値が存在すれば、要素のキーを返す array_search() | 配列(型) 2
3 文字列に含まれるすべての半角空白と全角空白を削除 | テキスト処理 2
3 現在WebページのURLパスを第2階層まで取得 | パス 2
3 array_walk第3引数を指定して、コールバック関数へ第3引数を渡す | 配列(型) 2
3 配列の内容(ひらがな)を、読み(あ行~わ行)で分け、新たな配列へ格納 | 配列(型) 2
3 指定文字列より前を取得 | 文字列(テキスト処理) 2
3 配列の空要素を削除(コールバック関数未使用) … array_filter() | 配列(型) 2
3 クロスサイトスクリプティング対策(配列対応) | エスケープ処理 2
3 isset | タグ毎エントリー一覧 2
3 平均値、分散、標準偏差を求める | 統計 2
4 switch文判定 … 「in_array」「array_keys」 | 配列(型) 1
4 (データベースなどから取得した)多次元配列の構造を変換して一次元配列を返す | 多次元配列(型) 1
4 「input type="datetime-local"」で受け取った文字列をハイフンへ変更 | 日付および時刻関連 1
4 mb_strpos | タグ毎エントリー一覧 1
4 配列要素をそれぞれ置換(引数の数 … 不一致) | 配列(型) 1
4 URLから、トップページ(index.html)判定 | ルーティング 1
2025/12/27 1:02 更新