Dom解析xml入门实例!!!!!!!!!!

dom解析优点,把xml文件全放的内存,快。适合小文件。 节点包含属性节点,文本节点,元素节点。dom里面都是节点

第一个简单点的dom解析,得到节点里面的文本节点

student.xml


<student>
    <name id="001">张三name>
    <sex>sex>
    <age>20age>
student>

demo.java

package xml;

import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;

import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.NodeList;

public class Demo1 {
    public static void main(String[] args) {
        //创建dom解析工厂
        DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
        try {
            DocumentBuilder builder=factory.newDocumentBuilder();
            Document doc=builder.parse("src\\main\\resources\\student.xml");
            NodeList nodeList=doc.getElementsByTagName("student");
            Element e=(Element)nodeList.item(0);
            //得到第一个student,然后得到第一个name节点,然后得到这个节点的一个节点,然后得到value。。。。记住节点包含属性节点,文本节点,元素节点。dom里面都是节点
            System.out.println("姓名:"+e.getElementsByTagName("name").item(0).getFirstChild().getNodeValue());
            System.out.println("性别:"+e.getElementsByTagName("sex").item(0).getFirstChild().getNodeValue());
            System.out.println("年龄:"+e.getElementsByTagName("age").item(0).getFirstChild().getNodeValue());
        } catch (Exception e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }

    }
}


姓名:张三
性别:男
年龄:20

第二个dom解析属性节点

stydents.xml


<students>
    <student>
        <name id="001" xx="哈哈">张三name>
        <sex>sex>
        <age>20age>
    student>
    <student>
        <name id="002">李四name>
        <sex>sex>
        <age>21age>
    student>
students>

java

package xml;

import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;

import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.NamedNodeMap;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;

public class Demo2 {
    //得到属性节点
    public static void printNodeAttr(Node node){
        NamedNodeMap namedNodeMap=node.getAttributes();
        for(int i=0;i
            Node attrNode=namedNodeMap.item(i);
            System.out.println(attrNode.getNodeName()+":"+attrNode.getFirstChild().getNodeValue());
        }
    }

    public static void main(String[] args) {
        DocumentBuilderFactory factory=DocumentBuilderFactory.newInstance();
        try {
            DocumentBuilder builder=factory.newDocumentBuilder();
            Document doc=builder.parse("src\\main\\resources\\students.xml");
            NodeList nodeList=doc.getElementsByTagName("students");
            Element element=(Element)nodeList.item(0);
            NodeList studentsNodeList=element.getElementsByTagName("student");
            for(int i=0;i
                Element e=(Element)studentsNodeList.item(i);
                System.out.println("姓名:"+e.getElementsByTagName("name").item(0).getFirstChild().getNodeValue());
                printNodeAttr(e.getElementsByTagName("name").item(0));
                System.out.println("性别:"+e.getElementsByTagName("sex").item(0).getFirstChild().getNodeValue());
                System.out.println("年龄:"+e.getElementsByTagName("age").item(0).getFirstChild().getNodeValue());
                System.out.println("================");
            }
        } catch (Exception e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
    }
}




姓名:张三
id:001
xx:哈哈
性别:男
年龄:20
================
姓名:李四
id:002
性别:女
年龄:21
================

你可能感兴趣的:(xml)