JAVA读取xml文件-----DOM方式
文件结构:
第一种
import java.io.File;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import org.junit.Test;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;
第一种
@Test
public void test1() {
Element element = null;
File f = new File("G://Def-19700119094553.xml");
// documentBuilder为抽象不能直接实例化(将XML文件转换为DOM文件)
DocumentBuilder db = null;
DocumentBuilderFactory dbf = null;
try {
dbf = DocumentBuilderFactory.newInstance();// 返回documentBuilderFactory对象
db = dbf.newDocumentBuilder();// 返回db对象用documentBuilderFatory对象获得返回documentBuildr对象
Document dt = db.parse(f);// 得到一个DOM并返回给document对象
element = dt.getDocumentElement();// 得到一个elment根元素
String root = element.getNodeName();// 获得根节点 Users
System.out.println("根元素:" + root);
NodeList childNodes = element.getChildNodes();// 获得根元素下的子节点
// 遍历这些子节点
for (int i = 0; i < childNodes.getLength(); i++) {
Node node1 = childNodes.item(i);// 获得每个对应位置i的结点 第几个User
if ("User".equals(node1.getNodeName())) { // 如果节点的名称为"User",则输出User元素属性type
//获得结点里面的属性使用getAttributes()
String type = node1.getAttributes().getNamedItem("type").getNodeValue();
System.out.println(type);
// 获得<User>下的节点
NodeList nodeDetail = node1.getChildNodes();
// 遍历<User>下的节点
for (int j = 0; j < nodeDetail.getLength(); j++) {
// 获得<Accounts>元素每一个节点
Node detail = nodeDetail.item(j);
if ("id".equals(detail.getNodeName())){ // 输出id
System.out.println("id: " + detail.getTextContent());
}else if ("name".equals(detail.getNodeName())){
System.out.println("姓名: " + detail.getTextContent());
}else if ("pwd".equals(detail.getNodeName())){
System.out.println("密码: " + detail.getTextContent());
}else if ("sex".equals(detail.getNodeName())){
System.out.println("性别: " + detail.getTextContent());
}
}
}
}
} catch (Exception e) {
e.printStackTrace();
}
}
第二种
@Test
public void test2() {
Element element = null;
File f = new File("G://Def-19700119094553.xml");
// 将xml文件转为dom文件
DocumentBuilder db = null;
DocumentBuilderFactory dbf = null;
try {
dbf = DocumentBuilderFactory.newInstance();
db = dbf.newDocumentBuilder();
// 得到一个dom并返回给document
Document dt = db.parse(f);
element = dt.getDocumentElement();
String root = element.getNodeName();// 获得根节点 Users
System.out.println("根元素:" + root);
NodeList childNodes = element.getChildNodes();// 获得根元素下的子节点
// 遍历子节点
for (int i = 0; i < childNodes.getLength(); i++) {
Node node1 = childNodes.item(i); // 获得每个对应位置i的结点 第几个RfidRecord
if ("RfidRecord".equals(node1.getNodeName())) {
String rfidTime = node1.getAttributes().getNamedItem("RfidTime").getNodeValue();// 获得结点里面的属性使用getAttributes()
String value = node1.getTextContent();// 获得结点之间的值用getTextContent()
// 输出结果
System.out.print("RfidTime" + rfidTime + "\t");
System.out.println(value);
}
}
} catch (Exception e) {
}
}
}
}
结果一:
结果二: