我有任意数量的列表,我想使用for宏处理.我想创建一个函数,它将向量作为绑定传递,因为列表的数量不同.
如果我硬编码绑定,它按预期工作:
=> (def list1 '("pink" "green"))
=> (def list2 '("dog" "cat"))
=> (for [A list1 B list2] (str A "-" B))
("pink-dog" "pink-cat" "green-dog" "green-cat")
Run Code Online (Sandbox Code Playgroud)
当我尝试单独创建一个向量并使用它作为绑定我遇到了问题.在这里,我手动创建绑定向量:
=> (def testvector (vec (list 'A list1 'B list2)))
Run Code Online (Sandbox Code Playgroud)
这似乎很好:
=> testvector
[A ("pink" "green") B ("dog" "cat")]
=> (class testvector)
clojure.lang.PersistentVector
Run Code Online (Sandbox Code Playgroud)
然而,
=> (for testvector (str A "-" B))
#<CompilerException java.lang.IllegalArgumentException: for requires a vector for its binding (NO_SOURCE_FILE:36)>
Run Code Online (Sandbox Code Playgroud)
我不明白为什么testvector在被用作for的绑定时不被认为是一个向量.抓住吸管,我把testvector放在方括号中,这样可以保持宏的快乐(它看到一个向量)但现在我有一个带有一个元素的向量(即向量中的向量),这不起作用,因为绑定需要成对的名称和集合.
=> (for [testvector] (str A "-" B))
#<CompilerException java.lang.IllegalArgumentException: for requires an …Run Code Online (Sandbox Code Playgroud)