zoukankan      html  css  js  c++  java
  • Java中读取xml方法

    package zaxiang;
    
    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 XMLReaderTest 
    {
    
         public static void main(String args[]) 
         {
              Element element = null;
              // 可以使用绝对路劲
              File f = new File("config/NewFile.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();
                   // 获得根节点
                   System.out.println("根元素:" + element.getNodeName());
                
                   // 获得根元素下的子节点
                   NodeList childNodes = element.getChildNodes();
                
                   // 遍历这些子节点
                   for (int i = 0; i < childNodes.getLength(); i++) 
                   {
                            // 获得每个对应位置i的结点
                            Node node1 = childNodes.item(i);
                            if ("Account".equals(node1.getNodeName())) 
                            {
                                 // 如果节点的名称为"Account",则输出Account元素属性type
                                 System.out.println("
    找到一篇账号. 所属区域: " + node1.getAttributes().getNamedItem("type").getNodeValue() + ". ");
                                 // 获得<Accounts>下的节点
                                 NodeList nodeDetail = node1.getChildNodes();
                                 // 遍历<Accounts>下的节点
                                 for (int j = 0; j < nodeDetail.getLength(); j++)
                                 {
                                          // 获得<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();
              }
         }
    }

    处理的xml文件内容:

    <?xml version="1.0" encoding="gbk"?>
    <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>
  • 相关阅读:
    获取label标签内for的属性值-js
    js万亿级数字转汉字的封装方法
    a标签的伪元素的应用——link,hover,visited,active
    JS声明变量的写法
    VUE环境配置步骤及相关Git Bash命令的使用
    display:inline-block下,元素不能在同一水平线及元素间无margin间距的问题解决方法
    css变量的用法——(--cssName)
    img的属性alt 与 title的区别
    返回结果的HTTP状态码——《图解http》第四章
    HTTP报文内部的HTTP信息——《图解HTTP》第三章
  • 原文地址:https://www.cnblogs.com/HCT118/p/4508941.html
Copyright © 2011-2022 走看看