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文件转换为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("\r\n找到一篇账号. 所属区域: " + node1.getattributes().getnameditem("type").getnodevalue() + ". ");
// 获得下的节点
nodelist nodedetail = node1.getchildnodes();
// 遍历下的节点
for (int j = 0; j < nodedetail.getlength(); j++) {
// 获得元素每一个节点
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();
}
}
}