dom4j组装xml 以及解析xml:

1.下载dom4j的jar包,地址:https://dom4j.github.io/

2.java代码:

package test;

import java.io.File;
import java.io.FileOutputStream;
import java.io.FileWriter;
import java.io.IOException;
import java.io.StringWriter;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map; import javax.xml.parsers.ParserConfigurationException; import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.DocumentHelper;
import org.dom4j.Element;
import org.dom4j.io.OutputFormat;
import org.dom4j.io.SAXReader;
import org.dom4j.io.XMLWriter;
import org.xml.sax.SAXException; /**
* dom4j解析xml
* @author lyc
*
*/
public class DOM4J { public static void main(String[] args) {
DOM4J dom4j= new DOM4J();
try {
//生成xml
dom4j.objectToXml();
//解析xml
//dom4j.xmlToObject();
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
} // 获取并解析xml格式文件为object
public void xmlToObject() throws ParserConfigurationException, DocumentException, SAXException, IOException{
/**
* 1.解析xml文件
*/
SAXReader saxReader = new SAXReader();
//将获取的xml 转化为document 文档
//这里使用了File当然也可以使用URL()从指定url获取xml并进行解析
//document从文件中解析出来
//Document document = saxReader.read(new File("src/1.xml")); /**
* 2.解析xml字符串
*/
//解析xml字符串
//document从字符串中解析出来
String xml = "<?xml version='1.0' encoding='UTF-8'?><student name='zhangsan'><courses><yuwen>语文</yuwen><shuxue>数学</shuxue></courses><courses><yingyu>英语</yingyu><huaxue>化学</huaxue></courses></student>";
Document document = DocumentHelper.parseText(xml); // 将字符串转为XML
// 获取根元素
Element root = document.getRootElement();
// 根元素名称
System.out.println("reservationList Root----: " + root.getName()); // 获取所有子元素
List<Element> childList = root.elements(); //解析xml串
System.out.println(childList.get(0).element("yuwen").getTextTrim());
System.out.println("courses child 长度:" + childList.size());
for(Element e : childList){
List<Element> list = e.elements();
for(Element e1 : list){
System.out.println(e1.getTextTrim());
}
System.out.println("==========");
} System.out.println("total reservation child count: " + childList.size());
System.out.println("第一个reservation的quotationId节点值:"+childList.get(0).element("quotationId").getTextTrim());
for(Element e : childList){
/*Element helloElement = e.element("quotationId");
System.out.println(helloElement.getTextTrim());*/ Element insurantListE = e.element("insurantList");
List<Element> insurantList = insurantListE.elements();
System.out.println("total insurant child count: " + insurantList.size());
for(Element e1 : insurantList){
Element helloElement1 = e1.element("insurantName");
System.out.println(helloElement1.getTextTrim());
}
} /*// 获取特定名称的子元素
List<Element> childList2 = root.elements("reservation");
Element helloElement = root.element("quotationId");
System.out.println("hello child: " + childList2.size());
// 获取特定名称的子元素的值
System.out.println("hello----"+childList2.get(0).getText());
System.out.println("hello----"+helloElement.getText().trim());
System.out.println("迭代输出-----------------------");*/ // 迭代输出
/*for (Iterator iter = root.elementIterator(); iter.hasNext();)
{ // 获取根目录下的元素
Element e = (Element) iter.next();
// 获取元素对应的值
System.out.println(e.getText());
// 元素的属性个数
System.out.println(e.attributeCount());
//获取元素的第一个属性的名称
System.out.println(e.attribute(0).getName());
//获取元素的第一个属性的值
System.out.println(e.attribute(0).getValue());
//获取元素的第二个属性的名称
System.out.println(e.attribute(1).getName());
//获取元素的第二个属性的值
System.out.println(e.attribute(1).getValue());
//按照属性名称获取属性值
System.out.println("are you ok :"+e.attributeValue("age"));
System.out.println("are you ok :"+e.attributeValue("name"));
}*/ // 使用DOMReader将xml转化为object
/*System.out.println("用DOMReader-----------------------");
DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
DocumentBuilder db = dbf.newDocumentBuilder();
// 注意要用完整类名
//将获取的xml 转化为document 文档
org.w3c.dom.Document document2 = db.parse(new File("F:/student2.xml")); DOMReader domReader = new DOMReader(); // 将JAXP的Document转换为dom4j的Document
Document document3 = domReader.read(document2); Element rootElement = document3.getRootElement(); System.out.println("Root: " + rootElement.getName());*/
} // 将对象组装成xml格式文件并保存
public void objectToXml ()throws Exception{
// 第一种方式:创建文档,并创建根元素
// 创建文档:使用了一个Helper类
Document document = DocumentHelper.createDocument();
// 创建根节点并添加进文档
Element root = DocumentHelper.createElement("student");
document.setRootElement(root); // 第二种方式:创建文档并设置文档的根元素节点
Element root2 = DocumentHelper.createElement("student");
Document document2 = DocumentHelper.createDocument(root2);
// 给元素添加属性
root2.addAttribute("name", "zhangsan"); Element e = root2.addElement("courses");
/*Map<String,Object> map1 = new HashMap<String,Object>();
Map<String,Object> map2 = new HashMap<String,Object>();
List<Map<String,Object>> list = new ArrayList(); map2.put("yuwen", "语文");
map2.put("shuxue", "数学");
list.add(map1);
list.add(map2);*/ /*for(Map map : list){
Element courseElement = e.addElement(map.entrySet().iterator().next().toString());
courseElement.setText(map.get(map.entrySet().iterator().next().toString()).toString());
}*/ Element yuwenElement = e.addElement("yuwen");
Element shuxueElement = e.addElement("shuxue"); yuwenElement.setText("语文");
shuxueElement.setText("数学"); /**
* 1.生成xml字符串
*/
//生成xml字符串方式一:
String xmlText = document2.asXML();
System.out.println(xmlText); //生成xml字符串方式二:
/*OutputFormat format1 = OutputFormat.createCompactFormat(); //createPrettyPrint() 层次格式化
StringWriter writer = new StringWriter();
XMLWriter output = new XMLWriter(writer, format1);
output.write(document);
System.out.println();
System.out.println("xmlToString:"+writer.toString());*/ /**
* 2.生成xml文件
*/
/* // 添加子节点:add之后就返回这个元素
Element helloElement = root2.addElement("hello");
Element worldElement = root2.addElement("world");
//给元素添加属性key-value
worldElement.addAttribute("age","12");
worldElement.addAttribute("name","www");
helloElement.addAttribute("age","13");
helloElement.addAttribute("name","wws");
//元素的节点的值
helloElement.setText("hello Text");
worldElement.setText("world text");*/
// 输出
// 输出到控制台
XMLWriter xmlWriter = new XMLWriter();
xmlWriter.write(document); //输出到文件
//其中的" "表示格式,true参数表示另起一行,gb2312表示编码,如果不写这个参数则默认utf-8编码
//1、OutputFormat format=new OutputFormat(" ",true,"gb2312");
//生成压缩格式、紧凑格式的xml 其中的compactFormat 翻译:压缩格式
//2、 OutputFormat format = OutputFormat.createCompactFormat();
//调用静态方法创建一个没有格式的打印方式
//3、 OutputFormat format = OutputFormat.createPrettyPrint();
//format.setEncoding("gb2312"); // 设置编码
OutputFormat format = new OutputFormat(" ", true);// 设置缩进为2个空格,并且另起一行为true
XMLWriter xmlWriter2 = new XMLWriter(
new FileOutputStream("C:/Users/lyc/Desktop/student1.xml"), format);
xmlWriter2.write(document2);
xmlWriter2.flush();
xmlWriter2.close(); // 另一种输出方式,记得要调用flush()方法,否则输出的文件中显示空白,调用close() 方法释放资源
XMLWriter xmlWriter3 = new XMLWriter(new FileWriter("C:/Users/lyc/Desktop/student2.xml"),
format);
xmlWriter3.write(document2);
xmlWriter3.flush();
xmlWriter3.close();
} }

3.需要解析的xml内容:
1.xml:(自己定义xml文件),例如:

<?xml version="1.0" encoding="UTF-8"?>

<student name="zhangsan">
<courses>
<yuwen>语文</yuwen>
<shuxue>数学</shuxue>
</courses>
</student>

4.生成xml文件:

student1.xml:

<?xml version="1.0" encoding="UTF-8"?>

<student name="zhangsan">
<courses>
<yuwen>语文</yuwen>
<shuxue>数学</shuxue>
</courses>
</student>

student2.xml:

<?xml version="1.0" encoding="UTF-8"?>

<student name="zhangsan">
<courses>
<yuwen>语文</yuwen>
<shuxue>数学</shuxue>
</courses>
</student>

dom4j组装xml 以及解析xml的更多相关文章

  1. python 解析XML python模块xml.dom解析xml实例代码

    分享下python中使用模块xml.dom解析xml文件的实例代码,学习下python解析xml文件的方法. 原文转自:http://www.jbxue.com/article/16587.html ...

  2. Dom生成Xml和解析Xml

    xml这样的文件格式在非常多时候都是非常适合我们用来存取数据的,所以利用程序来生成xml文件和解析xml文件就显得比較重要了.在dom中是把每个元素都看做是一个节点Node的,全部页面上的属性.元素等 ...

  3. 7.数据本地化CCString,CCArray,CCDictionary,tinyxml2,写入UserDefault.xml文件,操作xml,解析xml

     数据本地化 A CCUserDefault 系统会在默认路径cocos2d-x-2.2.3\projects\Hello\proj.win32\Debug.win32下生成一个名为UserDef ...

  4. Python使用xml.dom解析xml

    在菜鸟教程上找了个关于电影信息的xml类型的文档,用python内置的xml.dom来解析提取一下信息. 先复习一下xml概念: XML 指可扩展标记语言(EXtensible Markup Lang ...

  5. 基于Woodstox的StAX 2 (Streaming API for XML)解析XML

    StAX (Streaming API for XML)面向流的拉式解析XML,速度快.占用资源少,非常合适处理大数据量的xml文件. 详细教程和说明可以参见以下几篇文章: 使用 StAX 解析 XM ...

  6. Python—使用xml.sax解析xml文件

    什么是sax? SAX是一种基于事件驱动的API. 利用SAX解析XML文档牵涉到两个部分:解析器和事件处理器. 解析器负责读取XML文档,并向事件处理器发送事件,如元素开始跟元素结束事件; 而事件处 ...

  7. 对DOM,SAX,JDOM,DOM4J四种方法解析XML文件的分析

    1.DOM 与平台无关的官方解析方式 DOM是一次性把xml文件加载到内存中,形成一个节点树 对内存有要求 2.SAX java提供的基于事件驱动的解析方式 每次遇到一个标签,会触发相应的事件方法 3 ...

  8. [java开发篇][dom4j模块]遍历,解析xml

    package com.softwinner.performance.benchmark; /** * Created by Administrator on 2017/7/21. */ import ...

  9. SqL读取XML、解析XML、SqL将XML转换DataTable、SqL将XML转换表

    DECLARE @ItemMessage XML )) SET @ItemMessage=N' <ReceivablesInfos> <ReceivablesList> < ...

随机推荐

  1. iOS-UIImage imageWithContentsOfFile 和 imageName 对照

    1.imageWithContentsOfFile NSString *imagePath = [NSString stringWithFormat:@"%@/%@",[[NSBu ...

  2. poj 3259 bellman最短路推断有无负权回路

    Wormholes Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 36717   Accepted: 13438 Descr ...

  3. 【VC++游戏开发】智力游戏——鸡蛋里挑骨头(仿扫雷)

    在我学习游戏开发的过程中,遇到的最大的麻烦就是不知道一个游戏的完整实现过程,代码倒是其次. 这里,总结一下我做过的游戏.主要是梳理整每一个步骤. 先看下终于的效果 第1步,准备素材图片 包含鸡蛋.骨头 ...

  4. 算法 - 求一个数组的最长递减子序列(C++)

    //************************************************************************************************** ...

  5. 弹性ScrollView,和下啦刷新的效果相似 实现下拉弹回和上拉弹回

    今天做了一个弹性ScrollView,和下啦刷新的效果类似,我想这个非常多需求都用的这样的效果 事实上这是一个自己定义的scrollView,上代码.这是我写在一个公共的组件包里的 package c ...

  6. _00017 Kafka的体系结构介绍以及Kafka入门案例(0基础案例+Java API的使用)

    博文作者:妳那伊抹微笑 itdog8 地址链接 : http://www.itdog8.com(个人链接) 博客地址:http://blog.csdn.net/u012185296 博文标题:_000 ...

  7. CxImage内存方式转换图像

    最近,处于项目需要,需要将Bmp转换为JPEG格式.以前做过,采用的是GDI+的方式,该方式有一个极大地缺陷为无法实现跨平台处理.闲话少说,进入正题. CxImage cxImageBmp(pRGBB ...

  8. angular4(1)angular脚手架

    angular2之后有了类似于vue-cli的脚手架工具,很方便的帮助我们搭建项目: 1.安装angular命令行工具:npm install @angular/cli -g 2.检测angular- ...

  9. xBIM 基础12 WeXplorer xViewer的导航、相机、剖切、隐藏等操作

    系列目录    [已更新最新开发文章,点击查看详细]  本篇将学习xViewer的导航,剪切和隐藏.这应该足以使用户能够通过所有缩放,平移,轨道运行和隐藏可能的障碍物来检查建筑物内部.点击这里可以看到 ...

  10. Sql Server创建外键失败

    问题: 已成功保存“PPR_BasicInformation”表“PPR_PS”表- 无法创建关系“FK_PPR_PS_PPR_BasicInformation”. ALTER TABLE 语句与 F ...