DOM解析XML文档步骤

来源:互联网 发布:手机文档翻译软件 编辑:程序博客网 时间:2024/06/14 00:51

 //导入的包

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

import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;
import org.xml.sax.SAXException;




//得到DOM解析器的工厂实例

        DocumentBuilderFactory domfac=DocumentBuilderFactory.newInstance();
        //通过DOM工厂创建DOM解析器
        DocumentBuilder dombuilder=domfac.newDocumentBuilder();
        //得到要解析的XML文档的输入流
        InputStream is=new FileInputStream("bin/libracy.xml");
        //解析XML文档的输入流
        Document doc=dombuilder.parse(is);
        //得到XML文档的节点
        Element root=doc.getDocumentElement();
        //得到节点的子节点
        NodeList books=root.getChildNodes();
        //循环输出
        for(int i=0;i<books.getLength();i++)
        {
            //返回指定位置的Node对象
            Node book=books.item(i);
            String email=book.getAttributes().getNamedItem("email").getNodeValue();

            System.out.println(email);

       //遍历子节点
            for(Node node=book.getFirstChild();node!=null;node=node.getNextSibling())
            {
                if(node.getNodeName().equals("name")){
                    String name=node.getNodeValue();
                    String name1=node.getFirstChild().getNodeValue();
                    System.out.println(name);
                    System.out.println(name1);
                }
                if(node.getNodeName().equals("price")){
                    String price=node.getFirstChild().getNodeValue();
                    System.out.println(price);
                }
            }

        }

   //


原创粉丝点击