這篇文章主要介紹了Java讀取XML文件的方法,具有一定借鑒價(jià)值,需要的朋友可以參考下。希望大家閱讀完這篇文章后大有收獲。下面讓小編帶著大家一起了解一下。

直接上代碼吧,注釋寫(xiě)的很清楚了!
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;
// 可以使用絕對(duì)路勁
File f = new File("test.xml");
// documentBuilder為抽象不能直接實(shí)例化(將XML文件轉(zhuǎn)換為DOM文件)
DocumentBuilder db = null;
DocumentBuilderFactory dbf = null;
try {
// 返回documentBuilderFactory對(duì)象
dbf = DocumentBuilderFactory.newInstance();
// 返回db對(duì)象用documentBuilderFatory對(duì)象獲得返回documentBuildr對(duì)象
db = dbf.newDocumentBuilder();
// 得到一個(gè)DOM并返回給document對(duì)象
Document dt = db.parse(f);
// 得到一個(gè)elment根元素
element = dt.getDocumentElement();
// 獲得根節(jié)點(diǎn)
System.out.println("根元素:" + element.getNodeName());
// 獲得根元素下的子節(jié)點(diǎn)
NodeList childNodes = element.getChildNodes();
// 遍歷這些子節(jié)點(diǎn)
for (int i = 0; i < childNodes.getLength(); i++) {
// 獲得每個(gè)對(duì)應(yīng)位置i的結(jié)點(diǎn)
Node node1 = childNodes.item(i);
if ("Account".equals(node1.getNodeName())) {
// 如果節(jié)點(diǎn)的名稱(chēng)為"Account",則輸出Account元素屬性type
System.out.println("\r\n找到一篇賬號(hào). 所屬區(qū)域: " + node1.getAttributes().getNamedItem("type").getNodeValue() + ". ");
// 獲得<Accounts>下的節(jié)點(diǎn)
NodeList nodeDetail = node1.getChildNodes();
// 遍歷<Accounts>下的節(jié)點(diǎn)
for (int j = 0; j < nodeDetail.getLength(); j++) {
// 獲得<Accounts>元素每一個(gè)節(jié)點(diǎn)
Node detail = nodeDetail.item(j);
if ("code".equals(detail.getNodeName())) // 輸出code
System.out.println("卡號(hào): " + 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();
}
}
}然后我們測(cè)試的XML文件(test.xml)要放在項(xiàng)目工程的根目錄下,其內(nèi)容是:
<?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>
直接運(yùn)行代碼,輸出:
根元素:Accounts
找到一篇賬號(hào). 所屬區(qū)域: type1.
卡號(hào): 100001
密碼: 123
姓名: 李四
余額: 1000000.00
找到一篇賬號(hào). 所屬區(qū)域: type2.
卡號(hào): 100002
密碼: 123
姓名: 張三
余額: 1000.00
感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享Java讀取XML文件的方法內(nèi)容對(duì)大家有幫助,同時(shí)也希望大家多多支持創(chuàng)新互聯(lián),關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,遇到問(wèn)題就找創(chuàng)新互聯(lián),詳細(xì)的解決方法等著你來(lái)學(xué)習(xí)!
網(wǎng)站標(biāo)題:Java讀取XML文件的方法-創(chuàng)新互聯(lián)
當(dāng)前URL:http://chinadenli.net/article8/cociop.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供虛擬主機(jī)、App設(shè)計(jì)、微信小程序、ChatGPT、網(wǎng)站收錄、網(wǎng)站維護(hù)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容