Aquí hay una manera:
(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"})
Dependiendo de cómo espera que esos valores para cambiar, puede que prefiera algo más flexible:
(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"})
La elección de la representación argumento (vector para los parametros de búsqueda , argumentos desenrollados para los reemplazos) en create-converter
fue algo arbitrario para mí; no estoy seguro de si hay una regla para eso.
véase: http://stackoverflow.com/questions/2330281/how-can-i-update-a -vector-item-in-clojure –