Oto jeden ze sposobów:
(def people [ { :id 1 :name "Joe" } { :id 2 :name "Fred" } ])
(defn brian-converter [person]
(if (= 2 (:id person))
(assoc person :name "Brian")
person))
(map brian-converter people)
;;=> ({:id 1, :name "Joe"} {:id 2, :name "Brian"})
W zależności od tego, jak można oczekiwać wartości te zmiany, może wolisz coś bardziej elastyczne:
(defn create-converter [[key-to-match val-to-match]
key-to-replace val-to-replace]
(fn [person]
(if (= val-to-match (key-to-match person))
(assoc person key-to-replace val-to-replace)
person)))
(map (create-converter [:id 2] :name "Brian") people)
;;=> ({:id 1, :name "Joe"} {:id 2, :name "Brian"})
(map (create-converter [:id 1] :name "Dude") people)
;;=> ({:id 1, :name "Dude"} {:id 2, :name "Fred"})
wybór reprezentacji argument (wektor dla params wyszukiwania , rozwinięte argumenty dla zastępstw) w create-converter
były dla mnie arbitralne; nie wiem, czy jest na to reguła.
patrz: http://stackoverflow.com/questions/2330281/how-can-i-update-a -vector-item-in-clojure –