Java DOM XML Parser

2024-03-19 12:38
文章标签 java xml parser dom

本文主要是介绍Java DOM XML Parser,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

DOM parser parses the entire XML document and loads it into memory; then models it in a “TREE” structure for easy traversal or manipulation.

In short, it turns a XML file into DOM or Tree structure, and you have to traverse a node by node to get what you want.

Warning
DOM Parser is slow and consumes a lot of memory when it loads an XML document which contains a lot of data. Please consider SAX parser as solution for it, SAX is faster than DOM and use less memory.

1.0 How to read XML file in Java

/Users/mkyong/staff.xml

<?xml version="1.0"?>
<company><staff id="1001"><firstname>yong</firstname><lastname>mook kim</lastname><nickname>mkyong</nickname><salary>100000</salary></staff><staff id="2001"><firstname>low</firstname><lastname>yin fong</lastname><nickname>fong fong</nickname><salary>200000</salary></staff>
</company>

ReadXMLFile.java

package com.mkyong.seo;import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.DocumentBuilder;
import org.w3c.dom.Document;
import org.w3c.dom.NodeList;
import org.w3c.dom.Node;
import org.w3c.dom.Element;
import java.io.File;public class ReadXMLFile {public static void main(String argv[]) {try {File fXmlFile = new File("/Users/mkyong/staff.xml");DocumentBuilderFactory dbFactory = DocumentBuilderFactory.newInstance();DocumentBuilder dBuilder = dbFactory.newDocumentBuilder();Document doc = dBuilder.parse(fXmlFile);//optional, but recommended//read this - http://stackoverflow.com/questions/13786607/normalization-in-dom-parsing-with-java-how-does-it-workdoc.getDocumentElement().normalize();System.out.println("Root element :" + doc.getDocumentElement().getNodeName());NodeList nList = doc.getElementsByTagName("staff");System.out.println("----------------------------");for (int temp = 0; temp < nList.getLength(); temp++) {Node nNode = nList.item(temp);System.out.println("\nCurrent Element :" + nNode.getNodeName());if (nNode.getNodeType() == Node.ELEMENT_NODE) {Element eElement = (Element) nNode;System.out.println("Staff id : " + eElement.getAttribute("id"));System.out.println("First Name : " + eElement.getElementsByTagName("firstname").item(0).getTextContent());System.out.println("Last Name : " + eElement.getElementsByTagName("lastname").item(0).getTextContent());System.out.println("Nick Name : " + eElement.getElementsByTagName("nickname").item(0).getTextContent());System.out.println("Salary : " + eElement.getElementsByTagName("salary").item(0).getTextContent());}}} catch (Exception e) {e.printStackTrace();}}}

Result:

Root element :company
----------------------------Current Element :staff
Staff id : 1001
First Name : yong
Last Name : mook kim
Nick Name : mkyong
Salary : 100000Current Element :staff
Staff id : 2001
First Name : low
Last Name : yin fong
Nick Name : fong fong
Salary : 200000

Looping the Node
ReadXMLFile2.java

package com.mkyong.seo;import java.io.File;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import org.w3c.dom.Document;
import org.w3c.dom.NamedNodeMap;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;public class ReadXMLFile2 {public static void main(String[] args) {try {File file = new File("/Users/mkyong/staff.xml");DocumentBuilder dBuilder = DocumentBuilderFactory.newInstance().newDocumentBuilder();Document doc = dBuilder.parse(file);System.out.println("Root element :" + doc.getDocumentElement().getNodeName());if (doc.hasChildNodes()) {printNote(doc.getChildNodes());}} catch (Exception e) {System.out.println(e.getMessage());}}private static void printNote(NodeList nodeList) {for (int count = 0; count < nodeList.getLength(); count++) {Node tempNode = nodeList.item(count);// make sure it's element node.if (tempNode.getNodeType() == Node.ELEMENT_NODE) {// get node name and valueSystem.out.println("\nNode Name =" + tempNode.getNodeName() + " [OPEN]");System.out.println("Node Value =" + tempNode.getTextContent());if (tempNode.hasAttributes()) {// get attributes names and valuesNamedNodeMap nodeMap = tempNode.getAttributes();for (int i = 0; i < nodeMap.getLength(); i++) {Node node = nodeMap.item(i);System.out.println("attr name : " + node.getNodeName());System.out.println("attr value : " + node.getNodeValue());}}if (tempNode.hasChildNodes()) {// loop again if has child nodesprintNote(tempNode.getChildNodes());}System.out.println("Node Name =" + tempNode.getNodeName() + " [CLOSE]");}}}
}
2.0 How to modify XML file in Java

修改前xml file
file.xml

<?xml version="1.0" encoding="UTF-8" standalone="no" ?>
<company><staff id="1"><firstname>yong</firstname><lastname>mook kim</lastname><nickname>mkyong</nickname><salary>100000</salary></staff>
</company>

修改后xml

<?xml version="1.0" encoding="UTF-8" standalone="no" ?>
<company><staff id="2"><lastname>mook kim</lastname><nickname>mkyong</nickname><salary>2000000</salary><age>28</age></staff>
</company>

ModifyXMLFile .java修改xml

import java.io.File;
import java.io.IOException;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.ParserConfigurationException;
import javax.xml.transform.Transformer;
import javax.xml.transform.TransformerException;
import javax.xml.transform.TransformerFactory;
import javax.xml.transform.dom.DOMSource;
import javax.xml.transform.stream.StreamResult;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.NamedNodeMap;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;
import org.xml.sax.SAXException;public class ModifyXMLFile {public static void main(String argv[]) {try {String filepath = "c:\\file.xml";DocumentBuilderFactory docFactory = DocumentBuilderFactory.newInstance();DocumentBuilder docBuilder = docFactory.newDocumentBuilder();Document doc = docBuilder.parse(filepath);// Get the root elementNode company = doc.getFirstChild();// Get the staff element , it may not working if tag has spaces, or// whatever weird characters in front...it's better to use// getElementsByTagName() to get it directly.// Node staff = company.getFirstChild();// Get the staff element by tag name directlyNode staff = doc.getElementsByTagName("staff").item(0);// update staff attributeNamedNodeMap attr = staff.getAttributes();Node nodeAttr = attr.getNamedItem("id");nodeAttr.setTextContent("2");// append a new node to staffElement age = doc.createElement("age");age.appendChild(doc.createTextNode("28"));staff.appendChild(age);// loop the staff child nodeNodeList list = staff.getChildNodes();for (int i = 0; i < list.getLength(); i++) {Node node = list.item(i);// get the salary element, and update the valueif ("salary".equals(node.getNodeName())) {node.setTextContent("2000000");}//remove firstnameif ("firstname".equals(node.getNodeName())) {staff.removeChild(node);}}// write the content into xml fileTransformerFactory transformerFactory = TransformerFactory.newInstance();Transformer transformer = transformerFactory.newTransformer();DOMSource source = new DOMSource(doc);StreamResult result = new StreamResult(new File(filepath));transformer.transform(source, result);System.out.println("Done");} catch (ParserConfigurationException pce) {pce.printStackTrace();} catch (TransformerException tfe) {tfe.printStackTrace();} catch (IOException ioe) {ioe.printStackTrace();} catch (SAXException sae) {sae.printStackTrace();}}
}
3.0 How to create XML file in Java

要生成的xml file.xml

<?xml version="1.0" encoding="UTF-8" standalone="no" ?>
<company><staff id="1"><firstname>yong</firstname><lastname>mook kim</lastname><nickname>mkyong</nickname><salary>100000</salary></staff>
</company>

WriteXMLFile .java

package com.mkyong.core;import java.io.File;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.ParserConfigurationException;
import javax.xml.transform.Transformer;
import javax.xml.transform.TransformerException;
import javax.xml.transform.TransformerFactory;
import javax.xml.transform.dom.DOMSource;
import javax.xml.transform.stream.StreamResult;import org.w3c.dom.Attr;
import org.w3c.dom.Document;
import org.w3c.dom.Element;public class WriteXMLFile {public static void main(String argv[]) {try {DocumentBuilderFactory docFactory = DocumentBuilderFactory.newInstance();DocumentBuilder docBuilder = docFactory.newDocumentBuilder();// root elementsDocument doc = docBuilder.newDocument();Element rootElement = doc.createElement("company");doc.appendChild(rootElement);// staff elementsElement staff = doc.createElement("Staff");rootElement.appendChild(staff);// set attribute to staff elementAttr attr = doc.createAttribute("id");attr.setValue("1");staff.setAttributeNode(attr);// shorten way// staff.setAttribute("id", "1");// firstname elementsElement firstname = doc.createElement("firstname");firstname.appendChild(doc.createTextNode("yong"));staff.appendChild(firstname);// lastname elementsElement lastname = doc.createElement("lastname");lastname.appendChild(doc.createTextNode("mook kim"));staff.appendChild(lastname);// nickname elementsElement nickname = doc.createElement("nickname");nickname.appendChild(doc.createTextNode("mkyong"));staff.appendChild(nickname);// salary elementsElement salary = doc.createElement("salary");salary.appendChild(doc.createTextNode("100000"));staff.appendChild(salary);// write the content into xml fileTransformerFactory transformerFactory = TransformerFactory.newInstance();Transformer transformer = transformerFactory.newTransformer();DOMSource source = new DOMSource(doc);StreamResult result = new StreamResult(new File("C:\\file.xml"));// Output to console for testing// StreamResult result = new StreamResult(System.out);transformer.transform(source, result);System.out.println("File saved!");} catch (ParserConfigurationException pce) {pce.printStackTrace();} catch (TransformerException tfe) {tfe.printStackTrace();}}
}
4.0 How to count XML Elements in Java

file.xml

<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<company><staff id="1"><firstname>yong</firstname><lastname>mook kim</lastname><nickname>mkyong</nickname><salary>2000000</salary><age>29</age></staff><staff id="2"><firstname>low</firstname><lastname>yin fong</lastname><nickname>fong fong</nickname><salary>1000000</salary></staff><staff id="3"><firstname>Ali</firstname><lastname>Baba</lastname><nickname>Alibaba</nickname><salary>199000</salary><age>40</age></staff>
</company>

CountXMLElement.java

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.NodeList;
import org.xml.sax.SAXException;public class CountXMLElement {public static void main(String argv[]) {try {String filepath = "c:\\file.xml";DocumentBuilderFactory docFactory = DocumentBuilderFactory.newInstance();DocumentBuilder docBuilder = docFactory.newDocumentBuilder();Document doc = docBuilder.parse(filepath);NodeList list = doc.getElementsByTagName("staff");System.out.println("Total of elements : " + list.getLength());} catch (ParserConfigurationException pce) {pce.printStackTrace();} catch (IOException ioe) {ioe.printStackTrace();} catch (SAXException sae) {sae.printStackTrace();}}
}
5.0 解析网络xml

AlexaSEO.java

package com.mkyong.seo;import java.io.InputStream;
import java.net.URL;
import java.net.URLConnection;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.NodeList;public class AlexaSEO {public static void main(String[] args) {AlexaSEO obj = new AlexaSEO();System.out.println("Ranking : " + obj.getAlexaRanking("mkyong.com"));}public int getAlexaRanking(String domain) {int result = 0;String url = "http://data.alexa.com/data?cli=10&url=" + domain;try {URLConnection conn = new URL(url).openConnection();InputStream is = conn.getInputStream();DocumentBuilder dBuilder = DocumentBuilderFactory.newInstance().newDocumentBuilder();Document doc = dBuilder.parse(is);Element element = doc.getDocumentElement();NodeList nodeList = element.getElementsByTagName("POPULARITY");if (nodeList.getLength() > 0) {Element elementAttribute = (Element) nodeList.item(0);String ranking = elementAttribute.getAttribute("TEXT");if(!"".equals(ranking)){result = Integer.valueOf(ranking);}}} catch (Exception e) {System.out.println(e.getMessage());}return result;}
}

这篇关于Java DOM XML Parser的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/826020

相关文章

Spring Boot中的路径变量示例详解

《SpringBoot中的路径变量示例详解》SpringBoot中PathVariable通过@PathVariable注解实现URL参数与方法参数绑定,支持多参数接收、类型转换、可选参数、默认值及... 目录一. 基本用法与参数映射1.路径定义2.参数绑定&nhttp://www.chinasem.cnbs

JAVA中安装多个JDK的方法

《JAVA中安装多个JDK的方法》文章介绍了在Windows系统上安装多个JDK版本的方法,包括下载、安装路径修改、环境变量配置(JAVA_HOME和Path),并说明如何通过调整JAVA_HOME在... 首先去oracle官网下载好两个版本不同的jdk(需要登录Oracle账号,没有可以免费注册)下载完

Spring StateMachine实现状态机使用示例详解

《SpringStateMachine实现状态机使用示例详解》本文介绍SpringStateMachine实现状态机的步骤,包括依赖导入、枚举定义、状态转移规则配置、上下文管理及服务调用示例,重点解... 目录什么是状态机使用示例什么是状态机状态机是计算机科学中的​​核心建模工具​​,用于描述对象在其生命

Spring Boot 结合 WxJava 实现文章上传微信公众号草稿箱与群发

《SpringBoot结合WxJava实现文章上传微信公众号草稿箱与群发》本文将详细介绍如何使用SpringBoot框架结合WxJava开发工具包,实现文章上传到微信公众号草稿箱以及群发功能,... 目录一、项目环境准备1.1 开发环境1.2 微信公众号准备二、Spring Boot 项目搭建2.1 创建

Java中Integer128陷阱

《Java中Integer128陷阱》本文主要介绍了Java中Integer与int的区别及装箱拆箱机制,重点指出-128至127范围内的Integer值会复用缓存对象,导致==比较结果为true,下... 目录一、Integer和int的联系1.1 Integer和int的区别1.2 Integer和in

SpringSecurity整合redission序列化问题小结(最新整理)

《SpringSecurity整合redission序列化问题小结(最新整理)》文章详解SpringSecurity整合Redisson时的序列化问题,指出需排除官方Jackson依赖,通过自定义反序... 目录1. 前言2. Redission配置2.1 RedissonProperties2.2 Red

IntelliJ IDEA2025创建SpringBoot项目的实现步骤

《IntelliJIDEA2025创建SpringBoot项目的实现步骤》本文主要介绍了IntelliJIDEA2025创建SpringBoot项目的实现步骤,文中通过示例代码介绍的非常详细,对大家... 目录一、创建 Spring Boot 项目1. 新建项目2. 基础配置3. 选择依赖4. 生成项目5.

JSONArray在Java中的应用操作实例

《JSONArray在Java中的应用操作实例》JSONArray是org.json库用于处理JSON数组的类,可将Java对象(Map/List)转换为JSON格式,提供增删改查等操作,适用于前后端... 目录1. jsONArray定义与功能1.1 JSONArray概念阐释1.1.1 什么是JSONA

Java JDK1.8 安装和环境配置教程详解

《JavaJDK1.8安装和环境配置教程详解》文章简要介绍了JDK1.8的安装流程,包括官网下载对应系统版本、安装时选择非系统盘路径、配置JAVA_HOME、CLASSPATH和Path环境变量,... 目录1.下载JDK2.安装JDK3.配置环境变量4.检验JDK官网下载地址:Java Downloads

Spring boot整合dubbo+zookeeper的详细过程

《Springboot整合dubbo+zookeeper的详细过程》本文讲解SpringBoot整合Dubbo与Zookeeper实现API、Provider、Consumer模式,包含依赖配置、... 目录Spring boot整合dubbo+zookeeper1.创建父工程2.父工程引入依赖3.创建ap