java使用DOM操作XML
XML DOM简介
XML DOM 是用于获取、更改、添加或删除 XML 元素的标准。
XML 文档中的每个成分都是一个节点。
- DOM 是这样规定的:
整个文档是一个文档节点
每个 XML 标签是一个元素节点
包含在 XML 元素中的文本是文本节点
每一个 XML 属性是一个属性节点
注释属于注释节点
元素节点不包括文本,元素节点的文本是存储在文本节点中的。
XML 文档的 documentElement 属性是根节点。
在jdk中,Document接口继承自Node接口
Element接口也继承自Node接口
DOM方式读取XML文件
项目目录结构图:
config包下language.xml文件
<?xml version="1.0" encoding="UTF-8"?>
<languages cat = "it">
<lan id = "1">
<name>java</name>
<ide>Eclipse</ide>
</lan>
<lan id = "2">
<name>swift</name>
<ide>XCode</ide>
</lan>
<lan id = "3">
<name>C#</name>
<ide>Visual Studio</ide>
</lan>
</languages>
ReadXML.java
import java.io.File;
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 ReadXML {
public static void main(String[] args) {
try {
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
DocumentBuilder builder = factory.newDocumentBuilder();
Document document = builder.parse(new File("src/config/language.xml"));//解析文档
Element root = document.getDocumentElement(); //获取根节点
System.out.println("language=" + root.getAttribute("cat"));
System.out.println("-------------");
NodeList list = root.getElementsByTagName("lan");//获取根节点的标签名为“lan”的子节点
for (int i = 0; i < list.getLength(); i ++) {
Element lan = (Element) list.item(i); //遍历得到每个"lan"节点
System.out.println(lan.getTagName()+ "=" + lan.getAttribute("id"));
NodeList lanList = lan.getChildNodes(); //获取“lan”节点的子节点
for (int j = 0; j < lanList.getLength(); j++) {
Node node = lanList.item(j);
if (node instanceof Element) {
System.out.println(node.getNodeName()+"="+node.getTextContent());
}
}
System.out.println("*****************");
}
} catch (Exception e) {
e.printStackTrace();
}
}
}
控制台输出如下:
language=it
-------------
lan=1
name=java
ide=Eclipse
*****************
lan=2
name=swift
ide=XCode
*****************
lan=3
name=C#
ide=Visual Studio
*****************
DOM方式创建XML文件
项目结构图如下:

CreateXML.java文件
import java.io.File;
import java.io.StringWriter;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.ParserConfigurationException;
import javax.xml.transform.Transformer;
import javax.xml.transform.TransformerConfigurationException;
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;
public class CreateXML {
public static void main(String[] args) {
try {
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
DocumentBuilder builder = factory.newDocumentBuilder();
Document document = builder.newDocument();
Element languages = document.createElement("languages");
languages.setAttribute("cat", "it");
Element lan_1 = document.createElement("lan");
lan_1.setAttribute("id", "1");
Element name_1 = document.createElement("name");
name_1.setTextContent("Java");
Element ide_1 = document.createElement("ide");
ide_1.setTextContent("Eclipse");
lan_1.appendChild(name_1);
lan_1.appendChild(ide_1);
languages.appendChild(lan_1);
document.appendChild(languages);
//将构建好的xml输出
TransformerFactory transformerFactory = TransformerFactory.newInstance();
Transformer transformer = transformerFactory.newTransformer();
//输出到控制台
StringWriter writer = new StringWriter();
transformer.transform(new DOMSource(document), new StreamResult(writer));
System.out.println(writer.toString());
//输出到文件
transformer.transform(new DOMSource(document), new StreamResult(new File("language.xml")));
} catch (ParserConfigurationException e) {
e.printStackTrace();
} catch (TransformerConfigurationException e) {
e.printStackTrace();
} catch (TransformerException e) {
e.printStackTrace();
}
}
}
控制台输出如下:
<?xml version="1.0" encoding="UTF-8" standalone="no"?><languages cat="it"><lan id="1"><name>Java</name><ide>Eclipse</ide></lan></languages>
运行之后刷新项目目录,可看到已经产生language.xml文件:

language.xml文件:
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<languages cat="it">
<lan id="1">
<name>Java</name>
<ide>Eclipse</ide>
</lan>
</languages>
java使用DOM操作XML的更多相关文章
- Java用DOM操作xml
JAXP DOM方式解析XML文档实例增删改查package jiexi; import javax.xml.parsers.DocumentBuilder; import javax.xml.par ...
- php中通过DOM操作XML
DOM文档在js里早就接触过,知道DOM不但可以操作html文档,还可以操作XHTML,XML等文档,有着极强的通用性,下面我们通过两个小例子,看看在PHP中是如何用DOM操作XML文档的,和js中差 ...
- php : DOM 操作 XML
DOM 操作 XML 基本用法 XML文件: person.XML <?xml version="1.0" encoding="utf-8" ?> ...
- java通过dom读写xml文件
java通过dom读写xml文件 要读的xml文件 <?xml version="1.0" encoding="GB2312"?><学生花名册 ...
- Java原生API操作XML
使用Java操作XML的开源框架比较多,如著名的Dom4J.JDOM等,但个人认为不管你用那个框架都要对JDK原生的API有所了解才能更得心应手的应用.本篇就来简单了解下原生的XML API. JAV ...
- JAva使用DOM读取XML数据(解析)
原来一切都是有套路的 使用DOM解析XML文档步骤 1.创建解析器工厂对象 DocumentBuildFactory对象 2.由解析器工厂对象创建解析器对象,即DocumentBuilder对象 3. ...
- java DOM 操作xml
1 代码如下: package dom.pasing; import java.io.IOException; import java.io.StringWriter; import javax.xm ...
- DOM 操作XML(CRUD)
<?xml version="1.0" encoding="UTF-8" standalone="no"?><书架> ...
- Java中Dom解析xml文档
xml文档 <?xml version="1.0" encoding="UTF-8"?> <bookstore> <book id ...
随机推荐
- 【刷题】洛谷 P3950 部落冲突
题目背景 在一个叫做Travian的世界里,生活着各个大大小小的部落.其中最为强大的是罗马.高卢和日耳曼.他们之间为了争夺资源和土地,进行了无数次的战斗.期间诞生了众多家喻户晓的英雄人物,也留下了许多 ...
- NOI2010~NOI2018选做
[NOI2010] [NOI2010]海拔 高度只需要0/1,所以一个合法方案就是一个割,平面图求最小割. [NOI2010]航空管制 反序拓扑排序,每次取出第一类限制最大的放置,这样做答案不会更劣. ...
- Pentaho的Mondrian对Hive的支持
需求描述 考虑直接在Hive或者Impala等Big Data方案,能够支持MDX查询,现调研一下Mondrian对hive的支持情况. 环境准备 hive环境,采用hive-0.10-cdh4.2. ...
- vim 折叠的用法
http://www.cnblogs.com/fakis/archive/2011/04/14/2016213.html 1. 折叠方式 可用选项来设定折叠方式: 可在Vim 配置文件中设置 set ...
- phpmyadmin 配置方法
几乎所有的配置参数都在 config.inc.php 文件中.如果这个文件不存在,您可以在 libraries 目录中找到 config.default.php,将它复制到根目录,并改名为 confi ...
- struts2 的自定义 拦截器
Struts2的 拦截器: 对于拦截器,Struts2官方给出的 定义是: 拦截器是动态拦截Action调用的对象.它提供了一种机制,使开发者可以定义一段代码,在Action执行之前或者之后被调用执行 ...
- Android Studio添加文件注释头模板?
Self Settings: as中class文件头注释: File -> Settings -> Editor -> File and Code Templates -> 右 ...
- [JSOI2009] 球队收益 (费用流)
终于来发题解啦! pdf版题解 #include<iostream> #include<cstring> #include<cstdio> #include< ...
- jquery如何实现点击LI标签和下面的LI互换顺序? 超简单代码
转: jquery如何实现点击LI标签和下面的LI互换顺序? 上面的效果涉及jquery的两个方法: next() : 获得匹配元素集合中每个元素紧邻的下一个同胞元素. after() :在被选元 ...
- EndNote文献悬挂缩进的设置方法及设置参考文献序号后面空格长度
一.EndNote文献悬挂缩进的设置方法 写论文时使用EndNote来插入和管理参考文献是一种非常方便的方法,但有时不同的杂志要求插入的文献要求第二行缩进格式,或者不缩进. 1.在EndNote中Ed ...