我有一个地图矢量,我想以嵌套的方式进行转换。
数据结构如下:
(def data
[{:id 1 :name "a" :parent 0}
{:id 2 :name "b" :parent 0}
{:id 3 :name "c" :parent 0}
{:id 4 :name "a_1" :parent 1}
{:id 5 :name "a_2" :parent 1}
{:id 6 :name "b_1" :parent 2}
{:id 7 :name "a_1_1" :parent 4}])
每个映射都有一个:id
,一些其他的键和值对于这个讨论并不重要,:parent
键,表示元素是否属于另一个元素。如果:parent
为 0,则它是顶级元素。
我想嵌套这个扁平列表,以便属于父级的每个元素都存储在:nodes
父级映射中的一个键下,如下所示:
(def nested
[{:id 1 :name "a" :parent 0 :nodes
[{:id 4 :name "a_1" :parent 1 :nodes []}
{:id 5 :name "a_2" :parent 1 :nodes
[{:id 7 :name "a_1_1" :parent 4 :nodes []}]}]}
{:id 2 :name "b" :parent 0 :nodes
[{:id 6 :name "b_1" :parent 2}]}
{:id 3 :name "c" :parent 0 :nodes []}])
总而言之 - 我有一个扁平的树状结构,我希望再次变成一棵树。我尝试使用拉链来实现这一点,但未能处理任意嵌套级别。