Вот один из способов:
(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"})
В зависимости от того, как вы ожидаете изменения этих значений, вы можете предпочесть что-то более гибкое:
(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"})
Выбор представления аргумента (вектор дляпараметры поиска, развернутые аргументы для замен) в create-converter
были для меня как бы произвольны;не уверен, есть ли для этого правило.