如何用PHP將一維數(shù)組轉(zhuǎn)換為三層嵌套的樹狀結(jié)構(gòu)?

如何用PHP將一維數(shù)組轉(zhuǎn)換為三層嵌套的樹狀結(jié)構(gòu)?

本文探討如何高效地將php一維數(shù)組轉(zhuǎn)換為三層嵌套的樹狀結(jié)構(gòu)。給定一個包含項目名稱、型號和位置信息的數(shù)組,目標是將其轉(zhuǎn)換為樹形結(jié)構(gòu),項目名稱作為一級節(jié)點,型號為二級節(jié)點,位置為三級節(jié)點。

初始數(shù)組:

$arr = [     ['name' => "項目1", 'model' => "金", 'location' => '蘇州'],     ['name' => "項目1", 'model' => "銀", 'location' => '上海'],     ['name' => "項目2", 'model' => "銅", 'location' => '北京'],     ['name' => "項目2", 'model' => "銅", 'location' => '深圳'], ];

目標樹狀結(jié)構(gòu):

$target = [     [         'name' => "項目1",         'child' => [             ['model' => "金", 'child' => [['location' => '蘇州']]],             ['model' => "銀", 'child' => [['location' => '上海']]],         ]     ],     [         'name' => "項目2",         'child' => [             ['model' => "銅", 'child' => [['location' => '北京'], ['location' => '深圳']]],         ]     ], ];

之前的解決方案過于復(fù)雜。我們可以采用更簡潔、易于理解的方法,利用循環(huán)和條件判斷來構(gòu)建樹狀結(jié)構(gòu):

立即學(xué)習(xí)PHP免費學(xué)習(xí)筆記(深入)”;

$result = []; foreach ($arr as $item) {     $name = $item['name'];     $model = $item['model'];     $location = $item['location'];      // 查找或創(chuàng)建項目名稱節(jié)點     $nameIndex = array_search($name, array_column($result, 'name'));     if ($nameIndex === false) {         $result[] = ['name' => $name, 'child' => []];         $nameIndex = count($result) - 1;     }      // 查找或創(chuàng)建型號節(jié)點     $modelIndex = array_search($model, array_column($result[$nameIndex]['child'], 'model'));     if ($modelIndex === false) {         $result[$nameIndex]['child'][] = ['model' => $model, 'child' => []];         $modelIndex = count($result[$nameIndex]['child']) - 1;     }      // 添加位置節(jié)點     $result[$nameIndex]['child'][$modelIndex]['child'][] = ['location' => $location]; }  print_r($result); // 輸出轉(zhuǎn)換后的樹狀結(jié)構(gòu)

這段代碼首先初始化一個空數(shù)組 $result。然后,它迭代原始數(shù)組 $arr 中的每個項目。對于每個項目,它查找是否存在對應(yīng)的項目名稱和型號節(jié)點。如果不存在,則創(chuàng)建新的節(jié)點。最后,它將位置信息添加到相應(yīng)的型號節(jié)點下。 這種方法更清晰,也更容易維護。

這種方法避免了嵌套的 array_map 和 array_reduce,使其更易于理解和調(diào)試。 它直接操作數(shù)組,效率也更高。 選擇適合自己項目的方法,并根據(jù)實際情況調(diào)整代碼。

? 版權(quán)聲明
THE END
喜歡就支持一下吧
點贊12 分享