map-map、、map-map-keysおよびmap-map-values
Clojureには既存の関数がないことは知ってmap-map-valuesいますが、自由にコピーできる関数の実装を次に示します。これは、2つの密接に関連する機能が付属しています、map-mapそしてmap-map-keys、また、標準ライブラリから欠落しています:
(defn map-map
"Returns a new map with each key-value pair in `m` transformed by `f`. `f` takes the arguments `[key value]` and should return a value castable to a map entry, such as `{transformed-key transformed-value}`."
[f m]
(into (empty m) (map #(apply f %) m)) )
(defn map-map-keys [f m]
(map-map (fn [key value] {(f key) value}) m) )
(defn map-map-values [f m]
(map-map (fn [key value] {key (f value)}) m) )
使用法
次のmap-map-valuesように呼び出すことができます:
(map-map-values str {:a 1 :b 2})
;; => {:a "1", :b "2"}
そして、このような他の2つの関数:
(map-map-keys str {:a 1 :b 2})
;; => {":a" 1, ":b" 2}
(map-map (fn [k v] {v k}) {:a 1 :b 2})
;; => {1 :a, 2 :b}
代替実装
より一般的な関数なしで、map-map-keysまたはのみが必要な場合はmap-map-values、map-mapこれらに依存しない実装を使用できますmap-map。
(defn map-map-keys [f m]
(into (empty m)
(for [[key value] m]
{(f key) value} )))
(defn map-map-values [f m]
(into (empty m)
(for [[key value] m]
{key (f value)} )))
また、この言い回しを好む場合は、の代わりにmap-mapを使用した代替の実装を以下に示します。clojure.walk/walkinto
(defn map-map [f m]
(clojure.walk/walk #(apply f %) identity m) )
パラレルバージョン– pmap-map、など
必要に応じて、これらの関数の並列バージョンもあります。彼らは単にのpmap代わりに使用しますmap。
(defn pmap-map [f m]
(into (empty m) (pmap #(apply f %) m)) )
(defn pmap-map-keys [f m]
(pmap-map (fn [key value] {(f key) value}) m) )
(defn pmap-map-values [f m]
(pmap-map (fn [key value] {key (f value)}) m) )