• Java调用XML的方法:DocumentBuilderFactory .


    首先得到:得到 DOM 解析器的工厂实例      DocumentBuilderFactory domfac=DocumentBuilderFactory.newInstance();

    然后 DOM 工厂获得 DOM 解析器

     DocumentBuilder dombuilder=domfac.newDocumentBuilder();

    3 )把要解析的 XML 文档转化为输入流,以便 DOM 解析器解析它

    InputStream is= new  FileInputStream("test1.xml");        

    4 )解析 XML 文档的输入流,得到一个 Document

     Document doc=dombuilder.parse(is);

    5 )得到 XML 文档的根节点

    Element root=doc.getDocumentElement();

    6 )得到节点的子节点

      NodeList books=root.getChildNodes();

    Java代码 复制代码
    1. package com.st.demo;   
    2.   
    3. import java.io.File;   
    4. import java.io.FileInputStream;   
    5. import java.io.InputStream;   
    6.   
    7. import javax.xml.parsers.DocumentBuilder;   
    8. import javax.xml.parsers.DocumentBuilderFactory;   
    9.   
    10. import org.w3c.dom.Document;   
    11. import org.w3c.dom.Element;   
    12. import org.w3c.dom.Node;   
    13. import org.w3c.dom.NodeList;   
    14.   
    15. public class XmlReader {   
    16.     public static void main(String[] args) {   
    17.         XmlReader reader = new XmlReader();   
    18.     }   
    19.     public XmlReader(){   
    20.         DocumentBuilderFactory domfac = DocumentBuilderFactory.newInstance();   
    21.         try {   
    22.             DocumentBuilder domBuilder = domfac.newDocumentBuilder();   
    23.             InputStream is = new FileInputStream(new File("D:/test1.xml"));   
    24.             Document doc = domBuilder.parse(is);   
    25.             Element root = doc.getDocumentElement();   
    26.             NodeList books = root.getChildNodes();   
    27.             if(books!=null){   
    28.                 for (int i = 0; i < books.getLength(); i++) {   
    29.                     Node book = books.item(i);   
    30.                      if(book.getNodeType()==Node.ELEMENT_NODE) {   
    31.                             //(7)取得节点的属性值   
    32.                             String email=book.getAttributes().getNamedItem("email").getNodeValue();   
    33.                             System.out.println(email);   
    34.                             //注意,节点的属性也是它的子节点。它的节点类型也是Node.ELEMENT_NODE   
    35.                             //(8)轮循子节点   
    36.                             for(Node node=book.getFirstChild();node!=null;node=node.getNextSibling()) {   
    37.                                 if(node.getNodeType()==Node.ELEMENT_NODE) {   
    38.                                     if(node.getNodeName().equals("name")) {   
    39.                                         String name=node.getNodeValue();   
    40.                                         String name1=node.getFirstChild().getNodeValue();   
    41.                                         System.out.println(name);   
    42.                                         System.out.println(name1);   
    43.                                     }   
    44.                                     if(node.getNodeName().equals("price")) {   
    45.                                         String price=node.getFirstChild().getNodeValue();   
    46.                                         System.out.println(price);   
    47.                                     }   
    48.                                 }   
    49.                             }   
    50.                      }   
    51.                 }   
    52.             }   
    53.         } catch (Exception e) {   
    54.             // TODO Auto-generated catch block   
    55.             e.printStackTrace();   
    56.         }   
    57.            
    58.     }   
    59. }  
    Xml代码 复制代码
    1. <?xml version="1.0" encoding="GB2312" standalone="no"?>  
    2. <books>  
    3.     <book email="zhoujunhui">  
    4.         <name>rjzjh</name>  
    5.         <price>jjjjjj</price>  
    6.     </book>  
    7. </books>  
  • 相关阅读:
    SQLSERVER 中GO的作用
    工作相关工具介绍
    SQL Server 没有足够的内存继续执行程序 (mscorlib)的解决办法
    glyphicons-halflings-regular.woff2 not found 前台错误修正
    Asp.net MVC Pager分页实现
    金融相关网站
    Excel 函数使用
    C# 使用 Invoke 实现函数的白盒 UT 测试
    反编译工具
    SQL Server 数据库修改后不允许保存
  • 原文地址:https://www.cnblogs.com/hy928302776/p/3023436.html
Copyright © 2020-2023  润新知