首页 > 代码库 > JAVA中使用DOM解析XML文件
JAVA中使用DOM解析XML文件
JAVA中使用DOM解析XML文件:
import java.io.IOException;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.ParserConfigurationException;
import org.w3c.dom.Document;
import org.w3c.dom.NamedNodeMap;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;
import org.xml.sax.SAXException;
public class DOMtest {
public static void main(String[] args) {
// 创建DocumentBuilderFactory的对象
DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
try {
//创建DocumentBuilder对象
DocumentBuilder db = dbf.newDocumentBuilder();
//通过documentBuilder对象 的parser方法加载books。xml文件到当前项目下
Document document = db.parse("books.xml");
//获取所有book节点的集合
NodeList booklist = document.getElementsByTagName("book");
System.out.println("一共有"+booklist.getLength()+"本书");
//遍历每一个book节点
for(int i= 0; i<=booklist.getLength();i++){
//通过item(i)方法获取book节点
Node book = booklist.item(i);
//获取book节点的所有属性集合
NamedNodeMap attrs = book.getAttributes();
System.out.println("第"+(i+1)+"本书共有"+attrs.getLength()+"个属性");
//遍历book的属性
for(int j = 0;j<attrs.getLength();j++){
//通过item方法获取book节点的属性
Node attr = attrs.item(j);
//获取属性名
System.out.print("属性名:"+attr.getNodeName());
//获取属性值
System.out.println("--属性值"+attr.getNodeValue());
NodeList chilNod = book.getChildNodes();
System.out.println("第"+(i+1)+"本书共有"+chilNod.getLength()+"个子节点");
for(int k = 0;k<chilNod.getLength();k++){
Node chil = chilNod.item(k);
//区分text 类型node
if(chilNod.item(k).getNodeType() == Node.ELEMENT_NODE){
System.out.print("子节点名:"+chil.getNodeName()+":");
System.out.println(" 子节点值:"+chilNod.item(k).getFirstChild().getNodeValue());
//System.out.println("子节点值:"+chilNod.item(k).getTextContent());
}
}
}
}
} catch (ParserConfigurationException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (SAXException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
- 创建DocumentBuilderFactory的对象 DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
- 创建DocumentBuilder对象
- 通过documentBuilder对象的parser方法加载xml文件到当前项目下
- 获取所有XML文件内节点的集合 getElementsByTagName()方法
- 遍历每一个节点
- 通过item(i)方法获取节点
- 获取节点的所有属性集合 getAttributes()方法
- 遍历节点的属性 getNodeValue()
- 通过item()方法获取节点的属性
- 通过getNodeName()和getNodeValue()获取属性名和属性值
- 通过getChildNodes()获取子节点的集合
- 遍历子节点,获取子节点属性名和属性值 (注意: 区分text 类型的node,使用判断 if(chilNod.item(k).getNodeType() == Node.ELEMENT_NODE))
import java.io.IOException;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.ParserConfigurationException;
import org.w3c.dom.Document;
import org.w3c.dom.NamedNodeMap;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;
import org.xml.sax.SAXException;
public class DOMtest {
public static void main(String[] args) {
// 创建DocumentBuilderFactory的对象
DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
try {
//创建DocumentBuilder对象
DocumentBuilder db = dbf.newDocumentBuilder();
//通过documentBuilder对象 的parser方法加载books。xml文件到当前项目下
Document document = db.parse("books.xml");
//获取所有book节点的集合
NodeList booklist = document.getElementsByTagName("book");
System.out.println("一共有"+booklist.getLength()+"本书");
//遍历每一个book节点
for(int i= 0; i<=booklist.getLength();i++){
//通过item(i)方法获取book节点
Node book = booklist.item(i);
//获取book节点的所有属性集合
NamedNodeMap attrs = book.getAttributes();
System.out.println("第"+(i+1)+"本书共有"+attrs.getLength()+"个属性");
//遍历book的属性
for(int j = 0;j<attrs.getLength();j++){
//通过item方法获取book节点的属性
Node attr = attrs.item(j);
//获取属性名
System.out.print("属性名:"+attr.getNodeName());
//获取属性值
System.out.println("--属性值"+attr.getNodeValue());
NodeList chilNod = book.getChildNodes();
System.out.println("第"+(i+1)+"本书共有"+chilNod.getLength()+"个子节点");
for(int k = 0;k<chilNod.getLength();k++){
Node chil = chilNod.item(k);
//区分text 类型node
if(chilNod.item(k).getNodeType() == Node.ELEMENT_NODE){
System.out.print("子节点名:"+chil.getNodeName()+":");
System.out.println(" 子节点值:"+chilNod.item(k).getFirstChild().getNodeValue());
//System.out.println("子节点值:"+chilNod.item(k).getTextContent());
}
}
}
}
} catch (ParserConfigurationException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (SAXException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
JAVA中使用DOM解析XML文件
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。