DOM4J解析xml

来源:互联网 发布:美林数据股份有限公司 编辑:程序博客网 时间:2024/05/01 00:41



此处是要获取<service></service>根节点下面的<body></body>里的<data></data>具体数据     我只是截取了一部分xml,



      SAXReader sax = new SAXReader();   

    Document document = sax.read(new File("D:/XML/1400-0003返回报文.xml"));   //获取xml



 (1)Element root = document.getRootElement();   //获取xml的根节点,可以理解为最初的第一个标签节点.

    Element common = root.element("body").element("data"); //用Element 对象可以直接到你需要的节点处.

    List<Element> data = common.elements("data");  //因为我的xml里有很多<data></data>,所以用List<Element>来   

    接收所有的<data></data>节点,然后再根据需要相应的去取值就可以了.
for (int i = 0; i < data.size(); i++) {


if (("CH_CLIENT_NAME").equals(data.get(i).attribute("name").getValue())) {


String clientName = data.get(i).element("field").getStringValue();


System.out.println("clientName.." + clientName);
}

                }


        最后输出结果为:

         



另外,可以通过xpath方式解析更为方便。


//xpath

(2)直接拿到需要的节点

   List<Node> list = document.selectNodes("//data/field");

         for (Node n :list){

           

          System.out.println(n.getName());

          System.out.println(n.valueOf("@name"));

  }

0 0
原创粉丝点击