假设我们有一些如下的XML:
<a>
<b>
<c>text</c>
<d>
<e>text</e>
<f>
... lots of cruft here ..
</f>
</d>
</b>
<b>
...
</b>
<!-- more b sub-trees -->
</a>现在,查看zip_filter/xml.clj中的示例,我已经找到了如何获得我感兴趣的单个值。
我想知道如何做一些事情,比如返回成对的文本值(c,e)。
编辑:
这里有一些可以工作的代码,但它相当难看。不要求琐碎的重构,但是拉链有没有更好的方式让我们做到这一点呢?
(defn extract-data [xml]
(let [items (x/xml-> xml zf/descendants :Item) ;items not top-level
getAttributes #(x/xml1-> % :ItemAttributes) ;items have itemattributes
getASIN #(x/xml1-> % :ASIN x/text) ;items have ASINs
getTitle #(x/xml1-> % :Title x/text) ;itemattributes have Titles
getAuthor #(x/xml1-> % :Author x/text)] ;itemattributes have Authors
(map
;build a function to get everything we need from the items, and apply
#(let [attributes (getAttributes %)] ;get the attributes, we'll use it twice
(list
(getASIN %)
(getTitle attributes)
(getAuthor attributes)))
items)))发布于 2010-01-11 20:34:19
根据您使用的clojure版本,您可能会发现juxt函数很有用。您发布的代码(仅限相关部分):
(defn extract-data
[xml]
(let [...]
(map (juxt getASIN (comp getTitle getAttributes) (comp getAuthor getAttributes)) items))))发布于 2010-01-11 12:26:32
我相信有一种更好的方法,但这样做是可行的:
(letfn [(get-tag [tag coll] (:content (first (filter #(= tag (:tag %)) coll))))]
(map #(list (get-tag :c %) (get-tag :e (get-tag :d %)))
(map :content (:content (clojure.xml/parse "foo.xml")))))结果:
((["ctext1"] ["etext1"]) (["ctext2"] ["etext2"]))https://stackoverflow.com/questions/2034550
复制相似问题