JDOM生成、解析XML实例
import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.util.List;
import org.jdom.Attribute;
import org.jdom.Comment;
import org.jdom.Document;
import org.jdom.Element;
import org.jdom.JDOMException;
import org.jdom.input.SAXBuilder;
import org.jdom.output.Format;
import org.jdom.output.XMLOutputter;
/**
*
* jdom生成与解析XML文档
*
*/
public class JdomDemo{
Document document = new Document();
/**
* 利用JDom进行xml文档的写入操作
*/
public void createXml(File file) {
// 1.创建元素 及 设置为根元素
Element employees = newElement("employees");
document.setContent(employees);
// 2.创建注释 及 设置到根元素上
Comment commet = new Comment("thisis my comment");
employees.addContent(commet);
// 3.创建元素
Element element1 = newElement("employee");
// 3.1 设置元素的属性名及属性值
element1.setAttribute(newAttribute("id", "0001"));
// 3.2 创建元素的属性名及属性值
Attribute nameAttr = newAttribute("name", "wanglp");
// 3.3 设置元素名及文本
Element sexEle = newElement("sex");
sexEle.setText("m");
// 设置到上层元素上
element1.addContent(sexEle);
// 设置元素
Element ageEle = newElement("age");
ageEle.setText("22");
element1.addContent(ageEle);
// 设置为根元素的子元素
employees.addContent(element1);
// 将元素属性设置到元素上
element1.setAttribute(nameAttr);
// 3.创建元素
Element element2 = newElement("employee");
// 3.1 设置元素的属性名及属性值
element2.setAttribute(newAttribute("id", "0002"));
// 3.2 创建元素的属性名及属性值
Attribute name2Attr = newAttribute("name", "fox");
// 3.3 设置元素名及文本
Element sex2Ele = newElement("sex");
sex2Ele.setText("f");
// 设置到上层元素上
element2.addContent(sex2Ele);
// 设置元素
Element age2Ele = newElement("age");
age2Ele.setText("21");
element2.addContent(age2Ele);
// 设置为根元素的子元素
employees.addContent(element2);
// 将元素属性设置到元素上
element2.setAttribute(name2Attr);
Element element3 = new Element("employee");
element3.setText("title");
element3.addContent(newElement("name").addContent(new Element("hello")));
employees.addContent(element3);
// 设置xml文档输出的格式
Format format =Format.getPrettyFormat();
XMLOutputter out = newXMLOutputter(format);
// 将得到的xml文档输出到文件流中
try {
out.output(document, newFileOutputStream(file));
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
}
/**
* 利用JDom进行xml文档的读取操作
*/
public void parserXml(File file) {
// 建立解析器
SAXBuilder builder = new SAXBuilder();
try {
// 将解析器与文档关联
document = builder.build(file);
} catch (JDOMException e1) {
e1.printStackTrace();
} catch (IOException e1) {
e1.printStackTrace();
}
// 读取根元素
Element root =document.getRootElement();
// 输出根元素的名字
System.out.println("<" +root.getName() + ">");
// 读取元素集合
List<?> employeeList =root.getChildren("employee");
for (int i = 0; i <employeeList.size(); i++) {
Element ele = (Element) employeeList.get(i);
// 得到元素的名字
System.out.println("<"+ ele.getName() + ">");
// 读取元素的属性集合
List<?> empAttrList =ele.getAttributes();
for (int j = 0; j <empAttrList.size(); j++) {
Attribute attrs = (Attribute)empAttrList.get(j);
// 将属性的名字和值 并 输出
String name = attrs.getName();
String value = (String)attrs.getValue();
System.out.println(name +"=" + value);
}
try {
Element sex =ele.getChild("sex");
System.out.println("<sex>" + sex.getText());
Element age =ele.getChild("age");
System.out.println("<age>" + age.getText());
} catch (NullPointerException e) {
System.out.println(ele.getTextTrim());
Element name =ele.getChild("name");
System.out.println("<name>" + name.getName());
}
System.out.println("</employee>");
}
System.out.println("</employees>");
}
/**
* 测试
*/
public static void main(String[] args) {
JdomDemo jdom = new JdomDemo();
File file = newFile("E://jdom.xml");
jdom.createXml(file);
jdom.parserXml(file);
}
}
JDOM生成、解析XML实例的更多相关文章
- python 解析XML python模块xml.dom解析xml实例代码
分享下python中使用模块xml.dom解析xml文件的实例代码,学习下python解析xml文件的方法. 原文转自:http://www.jbxue.com/article/16587.html ...
- Python 解析XML实例(xml.sax)
已知movies.xml <collection shelf="New Arrivals"> <movie title="Enemy Behind&qu ...
- DOM4J生成、解析XML实例
import java.io.File; import java.io.FileWriter; import java.io.IOException; import java.util.Iterato ...
- java生成解析xml的另外两种方法Xstream
Xstream生成和解析xm和JAXB生成和解析xml的方法. 一,Xstream Xstream非jdk自带的,需要到入Xstream-1.4.3.jar和xpp3_min-1.1.4.jar 1. ...
- 【Android】使用Pull生成/解析XML文件
一.生成XML文件,即是将对象集合转为XML文件存储. 对象集合 –> XML(序列化) Android中使用android.util.Xml类对其进行了描述,提供相应的API. 步骤大致如下: ...
- java dom4j解析xml实例(2)
java利用dom4j解析xml 需要的jar包: dom4j官方网站在 http://www.dom4j.org/ 下载dom4j-1.6.1.zip 解开后有两个包,仅操作XML文档的话把dom4 ...
- java dom4j解析xml实例
java利用dom4j解析xml 需要的jar包: dom4j官方网站在 http://www.dom4j.org/ 下载dom4j-1.6.1.zip 解开后有两个包,仅操作XML文档的话把dom4 ...
- java 解析 XML实例
package com.hseact.fecp.servlet; import java.io.IOException; import javax.xml.parsers.DocumentBuilde ...
- DOM方式解析xml实例2
老样子,javabean实体类: import java.io.*; public class Book implements Serializable { private int id; priva ...
随机推荐
- ●BZOJ 3566 [SHOI2014]概率充电器
题链: http://www.lydsy.com/JudgeOnline/problem.php?id=3566题解: 概率dp,树形dp 如果求出每个点被通电的概率t, 那么期望答案就是t1×1+t ...
- hdu 5492 (暴力+nice)
题意:在矩阵中,找一条路从 (1,1)->(n,m),使方差最小 思路: T = (N+M−1)∑N+M−1i=1(Ai−Aavg)2 将N + M - 1乘进去,即求1 ~ N+M-1,(N ...
- tf.contrib.seq2seq.sequence_loss example:seqence loss 实例代码
#!/usr/bin/env python # -*- coding: utf-8 -*- import tensorflow as tf import numpy as np params=np.r ...
- python3全栈开发-补充UDP的套接字、操作系统、并发的理论基础
一.基于UDP的套接字 udp套接字简单示例 import socket ip_port=('1.1.1.1',8181) BUFSIZE=1024 udp_server_client=socket. ...
- JFinal 极速开发框架的优点和不足的地方
http://www.360doc.com/content/16/1226/10/31460730_617731802.shtml http://www.sohu.com/a/122571150_46 ...
- jquery easyui datagrid设置行样式 不可删除某行
rowStyler: function (index,row) { if (parseInt(row.ksrs) > 0) { return 'color:red'; } }, onLoadSu ...
- 在移动端画出真正的1px边框
一.问题 写H5的样式时候,设置元素的边框为1px,不幸的事情在IOS设备上发生了,设计师会说,咦,边框怎么那么大,这是2px了吧?改成1px.我明明设置成1px了啊. 二.为什么边框变粗了? ...
- TypeScript知识点
TypeScript介绍 TypeScript为JavaScript的超集(ECMAScript6), 这个语言添加了基于类的面向对象编程.TypeScript作为JavaScript很大的一个语法糖 ...
- js密码64加密
可以在客户端对密码进行简单的64位加密,服务端对应使用64位解密即可. /** * * Base64 encode / decode * * @author * @date * @email */ f ...
- Oracle知识梳理(一)理论篇:基本概念和术语整理
理论篇:基本概念和术语整理 一.关系数据库 关系数据库是目前应用最为广泛的数据库系统,它采用关系数据模型作为数据的组织方式,关系数据模型由关系的数据结构,关系的操作集合和关系的完整 ...