国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Java > 正文

Java如何讀取XML文件 具體實現(xiàn)

2019-11-26 15:51:18
字體:
供稿:網(wǎng)友

今天的CSDN常見問題來講解下在Java中如何讀取XML文件的內(nèi)容。

直接上代碼吧,注釋寫的很清楚了!

復(fù)制代碼 代碼如下:

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("test.xml");

  // documentBuilder為抽象不能直接實例化(將XML文件轉(zhuǎn)換為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();
   // 獲得根節(jié)點
   System.out.println("根元素:" + element.getNodeName());

   // 獲得根元素下的子節(jié)點
   NodeList childNodes = element.getChildNodes();

   // 遍歷這些子節(jié)點
   for (int i = 0; i < childNodes.getLength(); i++) {
    // 獲得每個對應(yīng)位置i的結(jié)點
    Node node1 = childNodes.item(i);
    if ("Account".equals(node1.getNodeName())) {
     // 如果節(jié)點的名稱為"Account",則輸出Account元素屬性type
     System.out.println("/r/n找到一篇賬號. 所屬區(qū)域: " + node1.getAttributes().getNamedItem("type").getNodeValue() + ". ");
     // 獲得<Accounts>下的節(jié)點
     NodeList nodeDetail = node1.getChildNodes();
     // 遍歷<Accounts>下的節(jié)點
     for (int j = 0; j < nodeDetail.getLength(); j++) {
      // 獲得<Accounts>元素每一個節(jié)點
      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文件(test.xml)要放在項目工程的根目錄下,其內(nèi)容是:

復(fù)制代碼 代碼如下:

<?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>

直接運行代碼,輸出:

根元素:Accounts

找到一篇賬號. 所屬區(qū)域: type1.
卡號: 100001
密碼: 123
姓名: 李四
余額: 1000000.00

找到一篇賬號. 所屬區(qū)域: type2.
卡號: 100002
密碼: 123
姓名: 張三
余額: 1000.00

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 镇坪县| 务川| 唐山市| 宁夏| 汾西县| 千阳县| 利辛县| 邢台市| 高密市| 金平| 东至县| 绥芬河市| 林周县| 昂仁县| 谢通门县| 彭山县| 涟源市| 安庆市| 金门县| 施甸县| 京山县| 涡阳县| 宁蒗| 辽宁省| 四会市| 峨眉山市| 汶上县| 大厂| 克什克腾旗| 英山县| 盖州市| 达尔| 白玉县| 永川市| 临邑县| 鹤壁市| 健康| 宁都县| 丰都县| 嘉义县| 台安县|