Java读取XML实现过程(DOM方式)
作者:诚ㅤㅤ
文章介绍了如何使用Java的DOM方式读取XML文件,并详细说明了读取过程中需要注意的事项,如文件路径、节点层级和属性值的获取方式,作者通过一个示例代码展示了如何实现XML的读取,并总结了自己的经验,希望对读者有所帮助
Java读取XML(DOM方式)
1、demo.xml文件内容
<?xml version="1.0" encoding="UTF-8"?> <Model> <user> <id Value="123">1</id> <userName>18888222111</userName> <passWord>2231231</passWord> <propertyes> <property Name="name" Value="张三" /> <property Name="age" Value="28" /> <property Name="sex" Value="男" /> </propertyes> </user> <user> <id>2</id> <userName>17888222111</userName> <passWord>3231231</passWord> <propertyes> <property Name="name" Value="张三22" /> <property Name="age" Value="23" /> <property Name="sex" Value="男" /> </propertyes> </user> <user> <id>3</id> <userName>197888222111</userName> <passWord>14231231</passWord> <propertyes> <property Name="Name" Value="张三33" /> <property Name="age" Value="21" /> <property Name="sex" Value="男" /> </propertyes> </user> </Model>
注意事项:
- 1、注意下xml所在包路径
- 2、里面每一层都可以理解为一个节点,读取时一直在对节点操作
- 3、注意当前读取节点的层数,目前是第几层节点
- 4、当前节点是以属性的方式设置的value还是在标签中间赋值
2、java代码
package com;
import org.w3c.dom.Document;
import org.w3c.dom.NamedNodeMap;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
/**
* @Author: wangxingcheng
* @DateTime: 2022/6/25 17:48
* @Description: 使用dom读取XML里面数据
*/
public class ReadXML {
public static void main(String[] args) {
readXML();
}
//解析XML数据
public static void readXML(){
try{
// 创建解析器工厂
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
DocumentBuilder db = factory.newDocumentBuilder();
// 创建一个Document对象 设置XML位置
Document doc = db.parse("src/com/xml/demo.xml");
//获取xml中Model节点
NodeList modelList = doc.getElementsByTagName("Model");
System.out.println("查询Model节点有几个========="+modelList.getLength());
//循环modelList节点,获取modelList里面的其他节点
for(int i = 0 ; i < modelList.getLength() ; i++){
Node model = modelList.item(i);
System.out.println("model ================"+model);
//获取model节点的子节点,上图可以看出model的子节点是user节点
NodeList userNodes = model.getChildNodes();
for(int j = 0 ; j < userNodes.getLength() ; j++){
//获取到user节点,循环取出每个user节点
Node user = userNodes.item(j);
//获取user节点的所有子节点集合里面有id、userName、passWord、propertyes节点
NodeList childNodes = user.getChildNodes();
for(int k = 0 ; k < childNodes.getLength() ; k++){
// 区分,去掉空格和换行符
if (childNodes.item(k).getNodeType() == Node.ELEMENT_NODE) {
//获取到有属性的节点了,打印看下是不是想要的id、userName、passWord、propertyes节点值和属性
Node node = childNodes.item(k);
System.out.print("属性名=========:" + node.getNodeName());
//xml根节点设值的位置将会决定他取值的不同
// 1、<id>123</id> 这种取值方式需要使用 .getTextContent() 方法才可以取到值
System.out.println("属性值=========:" + node.getTextContent());
// 第二种就是<property Name="Name" Value="张三" />这种写法的取值
//属性名=========:propertyes属性值=========:刚打印了下这里面每值,原因是这个节点本身没有值,切包含了其他节点
//这里做一手判断
if(node.getNodeName().equals("propertyes")){//这里再取里面节点的属性值,也是第二种取值方式
//获取propertyes里面的属性
NodeList propertyNodeList = node.getChildNodes();
for (int g = 0 ; g < propertyNodeList.getLength() ; g++) {
// 区分,去掉空格和换行符
if (propertyNodeList.item(g).getNodeType() == Node.ELEMENT_NODE) {
Node propertye = propertyNodeList.item(g);
//第二种取值方式来了,这个看图片很明显他把值都设置在对应的属性里面了,获取当前propertye节点的所有属性
NamedNodeMap attributes = propertye.getAttributes();
//<property Name="name" Value="张三" /> .getNodeValue()用来去属性里面设置的值
Node name = attributes.item(0);//表示第一个属性Name
Node value = attributes.item(1);//表示第二个属性Value
System.out.println("property的name值======"+name.getNodeValue());
System.out.println("property的value值======"+value.getNodeValue());
}
}
}
}
}
}
}
}catch (Exception e){
e.printStackTrace();
}
}
}
执行结果:

总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
