加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

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

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读