让我们看看 clojure.string/includes?
如何描述其所做之事及其实现
user=> (doc clojure.string/includes?)
-------------------------
clojure.string/includes?
([s substr])
True if s includes substr.
nil
user=> (source clojure.string/includes?)
(defn includes?
"True if s includes substr."
{:added "1.8"}
[^CharSequence s ^CharSequence substr]
(.contains (.toString s) substr))
nil
user=> (.toString (map :name [{:name "One"} {:name "Two"}]))
"clojure.lang.LazySeq@26e067"
user=> (.toString ["One" "Two"])
"[\"One\" \"Two\"]"
user=>
我们看到它假设其第一个参数是字符串 -- 或者更具体地说是一个 CharSequence
-- 然后从调用该参数的 .toString
开始。
我们看到 (.toString (map .. ..))
生成了一个看起来很神秘的字符串,但这是因为 map
产生了一个惰性序列,惰性序列的默认字符串表示是它的类型和十六进制值,就像任何没有特定字符串表示的 Java 对象一样。
但是,对一个引用列表或向量调用 .toString
会生成列表或向量的元素字符串表示。
因此,在后者的情况下,clojure.string/includes?
"works",即使您没有传入一个 CharSequence
,当它将数据结构转换为字符串时,也会包含您正在寻找的名称。
由于您想检查序列中的任何元素是否包含该字符串,您可能在这里想要的可能是
(some #(clojure.string/includes? % "Joni") (map :name (mapify ..)))