Clojure XML解析
发布时间:2020-12-16 02:01:21 所属栏目:百科 来源:网络整理
导读:我找不到任何有关如何解析XML文档和访问元素的信息。 我发现了两种方法来解析xml文档 (clojure.zip/xml-zip (clojure.xml/parse file)) 和 (parse-seq file) 但我似乎可以找到任何有关如何处理生成的结构的信息? 源文件是指zip-query.clj如何查询结果,但似
我找不到任何有关如何解析XML文档和访问元素的信息。
我发现了两种方法来解析xml文档 (clojure.zip/xml-zip (clojure.xml/parse file)) 和 (parse-seq file) 但我似乎可以找到任何有关如何处理生成的结构的信息? 源文件是指zip-query.clj如何查询结果,但似乎也失踪了。
假设您有以下xml来解析您的文件:
<high-node> <low-node>my text</low-node> </high-node> 你加载clojure.xml: user=> (use 'clojure.xml) 当解析时,xml将具有以下结构: {:tag :high-node,:attrs nil,:content [{:tag :low-node,:content ["my text"]}]} 然后可以对文件的内容进行seq以获取低节点的内容: user=> (for [x (xml-seq (parse (java.io.File. file))) :when (= :low-node (:tag x))] (first (:content x))) ("my text") 同样,如果你想访问低节点信息的整个列表,你可以改变:当谓词为(=(:high-node(:tag x))):) user=> (for [x (xml-seq (parse (java.io.File. file))) :when (= :high-node (:tag x))] (first (:content x))) ({:tag :low-node,:content ["my text"]}) 这是因为关键字可以作为函数操作。见Questions about lists and other stuff in Clojure和Data Structures: Keywords (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |