我正在学习如何在Clojure中具体地销毁数据结构,并且目前有以下示例数据
数据:
(def data [
{:category "A", :vertical_name "One", :vertical_id 11}
{:category "B", :vertical_name "Two", :vertical_id 12}
{:category "A", :vertical_name "Three", :vertical_id 13}
{:category "C", :vertical_name "Four", :vertical_id 14}
])我想将两个/更多的地图合并成一张地图,这些地图属于上述数据中相同的类别,
预期产出:
{{:category "A", :vertical [{:vertical_id 11, :vertical_name "One"}{:vertical_id 13, :vertical_name "Three"}]}
{:category "B", :vertical {:vertical_id 12, :vertical_name "Two"}}
{:category "C", :vertical {:vertical_id 14, :vertical_name "Four"}}}我试过了一组--这给了我
{"A" [{:category "A", :vertical_name "One", :vertical_id 11} {:category "A", :vertical_name "Three", :vertical_id 13}],
"B" [{:category "B", :vertical_name "Two", :vertical_id 12}],
"C" [{:category "C", :vertical_name "Four", :vertical_id 14}]}但是这有很多冗余的信息,例如,在所有的地图中都有:category "A",输出的格式不是我想要的。
提前谢谢你的帮助。
发布于 2014-08-27 18:21:14
user> (->> data
(group-by :category)
(map (fn [[k v]]
(let [vertical (map #(dissoc % :category) v)
vertical (if (< (count vertical) 2)
(first vertical)
(vec vertical))]
{:category k
:vertical vertical})))
set)
#{{:category "A", :vertical [{:vertical_name "One", :vertical_id 11} {:vertical_name "Three", :vertical_id 13}]} {:category "B", :vertical {:vertical_name "Two", :vertical_id 12}} {:category "C", :vertical {:vertical_name "Four", :vertical_id 14}}}这是您所描述的格式,但在大多数情况下,它将比group-by提供的输出更糟糕。与group-by结果不同,您无法以结果缩放的大小有效地查找给定的类别。此外,与group-by的结果不同,有时:vertical键有一个集合,有时只有一个元素,这是一个将复杂性卸载到访问该数据的任何其他代码上。
https://stackoverflow.com/questions/25533862
复制相似问题