java解析XML的方法详解编程语言

1.DOM 实现方法

xml文件

<?xml version="1.0" encoding="utf-8"?> 
<Accounts> 
   <Account type="type1"> 
         <code>100001</code> 
         <pass>123</pass> 
         <name>张三</name> 
         <money>1000000.00</money> 
   </Account> 
   <Account type="type2"> 
       <code>100002</code> 
       <pass>123</pass> 
       <name>李四</name> 
       <money>1000.00</money> 
    </Account> 
</Accounts>

java文件

package dom; 
 
import java.io.*; 
import javax.xml.parsers.DocumentBuilder; 
import javax.xml.parsers.DocumentBuilderFactory; 
import org.w3c.dom.Document; 
import org.w3c.dom.Element; 
import org.w3c.dom.Node; 
import org.w3c.dom.NodeList; 
 
 
public class Dom { 
 
    public static void main(String arge[]) { 
 
        Element element = null; 
        // 可以使用绝对路劲 
        File f = new File("dom/book.xml"); 
 
        // documentBuilder为抽象不能直接实例化(将XML文件转换为DOM文件) 
        DocumentBuilder db = null; 
        DocumentBuilderFactory dbf = null; 
        try { 
            // 返回documentBuilderFactory返回工厂对象 
            dbf = DocumentBuilderFactory.newInstance(); 
            // 返回db对象用documentBuilderFatory对象获得返回documentBuildr对象 
            db = dbf.newDocumentBuilder(); 
 
            // 得到一个DOM并返回给document对象 
            Document dt = db.parse(f); 
            // 得到一个elment根元素 
            element = dt.getDocumentElement(); 
            // 输出根元素的name 
            System.out.println("根元素:" + element.getNodeName());//Accounts 
 
            // 获得根元素下的子节点 
            NodeList childNodes = element.getChildNodes(); 
 
            // 遍历根节点下的所有子节点 
            for (int i = 0; i < childNodes.getLength(); i++) {//5 #text Account #text Account #text  会把回车算成子节点,实际只有两个子节点 
                // 获得每个对应位置i的结点 
                Node node1 = childNodes.item(i); 
                System.out.println("分别是="+node1.getNodeName()); 
                if ("Account".equals(node1.getNodeName())) { 
                    // 如果节点的名称为"Account",则输出Account元素属性type 
                    //NamedNodeMap   nnm = node1.getAttributes()的返回值是NamedNodeMap对象  
                    //通过节点名称返回结点对象Node node = getNamedItem("type") 
                    //getNodeValue()返回的是xml节点的值 
                    System.out.println("/r/n找到一篇账号. 所属区域: " 
                            + node1.getAttributes().getNamedItem("type") 
                                    .getNodeValue() + ". "); 
                    // 获得<Accounts>下的节点 
                    NodeList nodeDetail = node1.getChildNodes(); 
                    // 遍历<Accounts>下的节点 
                    for (int j = 0; j < nodeDetail.getLength(); j++) {//9 #text  code  #text  pass #text  name  #text  money #text  
                        // 获得<Accounts>元素每一个节点 
                        Node detail = nodeDetail.item(j); 
                        if ("code".equals(detail.getNodeName())) // 输出code 
                            System.out 
                                    .println("卡号: " + detail.getTextContent()); 
                        else if ("pass".equals(detail.getNodeName())) // 输出pass 
                            System.out 
                                    .println("密码: " + detail.getTextContent()); 
                        else if ("name".equals(detail.getNodeName())) // 输出name 
                            System.out 
                                    .println("姓名: " + detail.getTextContent()); 
                        else if ("money".equals(detail.getNodeName())) // 输出money 
                            System.out 
                                    .println("余额: " + detail.getTextContent()); 
                    } 
                } 
 
            } 
        } 
 
        catch (Exception e) { 
            e.printStackTrace(); 
        } 
    } 
 
}

2.DOM4J 实现方法

XML文件

<?xml version="1.0" encoding="UTF-8"?> 
  <RESULT>  
    <VALUE >  
      <NO>A1234</NO>  
      <ADDR>河南省郑州市</ADDR>  
    </VALUE>  
    <VALUE>  
      <NO>B1234</NO>  
      <ADDR>河南省郑州市二七区</ADDR>  
    </VALUE>  
</RESULT>

java文件

package dom4J; 
 
import java.io.*;    
import java.util.*;    
import org.dom4j.*;    
import org.dom4j.io.*;  
 
public class Test { 
 
    public static void main(String arge[]) { 
         
        try { 
            File f = new File("dom4J/a.xml"); 
            SAXReader reader = new SAXReader(); 
            //得到Document对象 
            Document doc = reader.read(f); 
            //获得根节点 
            Element root = doc.getRootElement(); 
            Element foo; 
            //elementIterator从根节点遍历子节点 
            Iterator i = root.elementIterator("VALUE"); 
            while(i.hasNext()){ 
            //for (Iterator i = root.elementIterator("VALUE"); i.hasNext();) { 
                foo = (Element) i.next(); 
                //得到节点的内容 
                System.out.print("车牌号码:" + foo.elementText("NO")); 
                System.out.println("车主地址:" + foo.elementText("ADDR")); 
            } 
        } catch (Exception e) { 
            e.printStackTrace(); 
        } 
    } 
}

3.JDOM实现方法

XML和上面相同,java代码如下

package jdom; 
 
import java.io.File; 
import java.util.List; 
 
import org.jdom.Document; 
import org.jdom.Element; 
import org.jdom.input.SAXBuilder; 
 
public class Test { 
    public static void main(String arge[]) { 
     
        try { 
            SAXBuilder builder = new SAXBuilder(); 
            Document doc = builder.build(new File("jdom/a.xml")); 
            Element foo = doc.getRootElement(); 
            List allChildren = foo.getChildren(); 
            for (int i = 0; i < allChildren.size(); i++) { 
                System.out.print("车牌号码:" 
                        + ((Element) allChildren.get(i)).getChild("NO") 
                                .getText()); 
                System.out.println("车主地址:" 
                        + ((Element) allChildren.get(i)).getChild("ADDR") 
                                .getText()); 
            } 
        } catch (Exception e) { 
            e.printStackTrace(); 
        } 
    } 
}

注意:2,3方法需要引入相对应的jar包使用

原创文章,作者:奋斗,如若转载,请注明出处:https://blog.ytso.com/tech/pnotes/11724.html

(0)
上一篇 2021年7月19日 11:49
下一篇 2021年7月19日 11:49

相关推荐

发表回复

登录后才能评论