Clojure 如何在向量中搜索元素区域?
我有一个字符串向量,这些字符串基本上是一个文本文档,格式类似于markdown 文档中有如下部分:Clojure 如何在向量中搜索元素区域?,clojure,Clojure,我有一个字符串向量,这些字符串基本上是一个文本文档,格式类似于markdown 文档中有如下部分: ===FooHeader=== stuff... more stuff... ---- (defn find-region [start? end? data] (take-while (complement end?) (drop-while (complement start?) data))) user=> (find-region #{1}
===FooHeader===
stuff...
more stuff...
----
(defn find-region [start? end? data]
(take-while (complement end?)
(drop-while (complement start?) data)))
user=> (find-region #{1} #{-1} [10 20 30 1 30 4 2 3 4 -1 1])
;;=> (1 30 4 2 3 4)
该部分的末尾用4个破折号表示
在这个向量中,可能有很多部分
我想从文档中提取一个特定部分
这样做的惯用方法是什么?它可能看起来像这样:
===FooHeader===
stuff...
more stuff...
----
(defn find-region [start? end? data]
(take-while (complement end?)
(drop-while (complement start?) data)))
user=> (find-region #{1} #{-1} [10 20 30 1 30 4 2 3 4 -1 1])
;;=> (1 30 4 2 3 4)
或者在您的情况下:
(find-region #{"===FooHeader==="} #{"----"} lines)
它可能看起来像这样:
===FooHeader===
stuff...
more stuff...
----
(defn find-region [start? end? data]
(take-while (complement end?)
(drop-while (complement start?) data)))
user=> (find-region #{1} #{-1} [10 20 30 1 30 4 2 3 4 -1 1])
;;=> (1 30 4 2 3 4)
或者在您的情况下:
(find-region #{"===FooHeader==="} #{"----"} lines)
基于节的名称,这只是一个字符串。我想不出我将使用哪些函数来实现此目的。基于节的名称,这只是一个字符串。我想不出我将使用哪些函数实现此目的。很漂亮。我喜欢。我还想知道你为什么在回答中使用集合,我是Clojure的新手,所以我想知道原因是什么。@BlaineLafreniere集合可以用作函数,基本上可以更容易地测试等式
{1}
基本上与函数(fn[x](=x1))
相同,并且随着向集合中添加更多元素以测试更多内容,它会变得更好。请注意(#{1}1)
和(#{1}2)
的计算结果。我喜欢。我还想知道你为什么在回答中使用集合,我是Clojure的新手,所以我想知道原因是什么。@BlaineLafreniere集合可以用作函数,基本上可以更容易地测试等式{1}
基本上与函数(fn[x](=x1))
相同,并且随着向集合中添加更多元素以测试更多内容,它会变得更好。注意(#{1}1)
和(#{1}2)
的计算结果。