此片文章主要写一些关于如何在maven工程中使用dom4j来解析或生成XML的建议方法,实际可使用的写法不仅限于如下所写的样例代码。此处进攻快速入手和提供思路使用。

首先配置pom.xml中的依赖的包

  1. <dependencies>
  2. <dependency>
  3. <groupId>dom4j</groupId>
  4. <artifactId>dom4j</artifactId>
  5. <version>1.6.1</version>
  6. </dependency>
  7. <dependency>
  8. <groupId>junit</groupId>
  9. <artifactId>junit</artifactId>
  10. <version>4.11</version>
  11. </dependency>
  12. <dependency>
  13. <groupId>jaxen</groupId>
  14. <artifactId>jaxen</artifactId>
  15. <version>1.1.6</version>
  16. </dependency>
  17. </dependencies>

上述配置中jaxen的包主要在使用Xpath时会被用到。

需要解析的样例XML文件

  1. <?xml version="1.0" encoding="UTF-8" ?>
  2. <resources>
  3. <product name="QQ">
  4. <account id="123456789">
  5. <nickname>qq-account-1</nickname>
  6. <password>qwe123qwe123</password>
  7. <level>56</level>
  8. </account>
  9. <account id="987654321">
  10. <nickname>qq-account-2</nickname>
  11. <password>ios9ios9ios9</password>
  12. <level>12</level>
  13. </account>
  14. </product>
  15. <product name="Netease">
  16. <account id="tom">
  17. <password>pwdOfTom</password>
  18. <capacity>1024</capacity>
  19. </account>
  20. <account name="Jim">
  21. <password>pwdOfJim</password>
  22. <capacity>2560</capacity>
  23. </account>
  24. </product>
  25. </resources>

解析的java类

  1. package com.jeremy;
  2. import org.dom4j.*;
  3. import org.dom4j.io.SAXReader;
  4. import org.dom4j.io.XMLWriter;
  5. import org.dom4j.xpath.DefaultXPath;
  6. import java.io.IOException;
  7. import java.io.PrintWriter;
  8. import java.util.ArrayList;
  9. import java.util.Iterator;
  10. import java.util.List;
  11. /**
  12. * Created by jeremysong on 1/7/2016.
  13. */
  14. public class DomParser
  15. {
  16. public static List<String> parseMethod1() throws DocumentException
  17. {
  18. List<String> result = new ArrayList<String>();
  19. SAXReader reader = new SAXReader();
  20. Document document = reader.read("E:\\IdeaProjects\\Example\\NetApp\\src\\main\\resources\\target.xml");
  21. XPath xPath = new DefaultXPath("/resources/product[@name='QQ']/account[@id='987654321']/password");
  22. List<Element> list = xPath.selectNodes(document.getRootElement());
  23. for (Element element : list)
  24. {
  25. System.out.println(element.getTextTrim());
  26. result.add(element.getTextTrim());
  27. }
  28. return result;
  29. }
  30. public static List<String> parseMethod2() throws DocumentException
  31. {
  32. List<String> result = new ArrayList<String>();
  33. SAXReader reader = new SAXReader();
  34. Document document = reader.read("E:\\IdeaProjects\\Example\\NetApp\\src\\main\\resources\\target.xml");
  35. List<Element> products = document.getRootElement().selectNodes("/resources/product");
  36. Iterator iterator = products.iterator();
  37. while (iterator.hasNext())
  38. {
  39. Element product = (Element) iterator.next();
  40. String name = product.attributeValue("name");
  41. System.out.println(name);
  42. }
  43. return result;
  44. }
  45. public static void generate()
  46. {
  47. Document doc = DocumentHelper.createDocument();
  48. Element root = doc.addElement("resources");
  49. Element product = root.addElement("product");
  50. product.addAttribute("name", "QQ");
  51. Element account = product.addElement("account");
  52. account.addAttribute("id", "123456789");
  53. Element nickname = account.addElement("nickname");
  54. nickname.setText("QQ-account-1");
  55. Element password = account.addElement("password");
  56. password.setText("123asd21qda");
  57. Element level = account.addElement("level");
  58. level.setText("56");
  59. PrintWriter pWriter = null;
  60. XMLWriter xWriter = null;
  61. try
  62. {
  63. pWriter = new PrintWriter("E:\\IdeaProjects\\Example\\NetApp\\src\\main\\generate.xml");
  64. xWriter = new XMLWriter(pWriter);
  65. xWriter.write(doc);
  66. } catch (Exception e)
  67. {
  68. e.printStackTrace();
  69. } finally
  70. {
  71. try
  72. {
  73. xWriter.flush();
  74. xWriter.close();
  75. } catch (IOException e)
  76. {
  77. e.printStackTrace();
  78. }
  79. }
  80. }
  81. }

测试类:

  1. import com.jeremy.DomParser;
  2. import org.dom4j.DocumentException;
  3. import org.junit.Test;
  4. /**
  5. * Created by jeremysong on 1/7/2016.
  6. */
  7. public class TestDomParser
  8. {
  9. @Test
  10. public void testParseMethod1() throws DocumentException
  11. {
  12. DomParser.parseMethod1();
  13. }
  14. @Test
  15. public void testParseMethod2() throws DocumentException
  16. {
  17. DomParser.parseMethod2();
  18. }
  19. @Test
  20. public void testGenerate()
  21. {
  22. DomParser.generate();
  23. }
  24. }

测试结果:

testParseMethod1运行结果

testParseMethod2运行结果

testGenerate运行结果

    1. <?xml version="1.0" encoding="UTF-8"?>
    2. <resources>
    3. <product name="QQ">
    4. <account id="123456789">
    5. <nickname>QQ-account-1</nickname>
    6. <password>123asd21qda</password>
    7. <level>56</level>
    8. </account>
    9. </product>
    10. </resources>

引用原文:https://blog.csdn.net/jeremysong88/article/details/50479924

写博客是为了记住自己容易忘记的东西,另外也是对自己工作的总结,文章可以转载,无需版权。希望尽自己的努力,做到更好,大家一起努力进步!

如果有什么问题,欢迎大家一起探讨,代码如有问题,欢迎各位大神指正!

maven中使用dom4j解析、生成XML的简易方法的更多相关文章

  1. Java中使用DOM4J来生成xml文件和解析xml文件

    一.前言 现在有不少需求,是需要我们解析xml文件中的数据,然后导入到数据库中,当然解析xml文件也有好多种方法,小编觉得还是DOM4J用的最多最广泛也最好理解的吧.小编也是最近需求里遇到了,就来整理 ...

  2. 转:在java中使用dom4j解析xml

    JAVA 使用Dom4j 解析XML Java DOM4J Parser - Parse XML Document Dom4j下载及使用Dom4j读写XML简介 在java中使用dom4j解析xml ...

  3. java中利用dom4j解析XML文件

    官网下载Dom4j地址:https://dom4j.github.io/ 注意:使用Dom4j开发,需下载dom4j相应的jar文件 题目:后台利用dom4j解析student.xml文件,并返回Li ...

  4. 编写Java程序,现要求使用 dom4j 解析 city.xml 文档,实现省份及对应城市的联动特效,效果如图所示

    查看本章节 查看作业目录 需求说明: 现要求使用 dom4j 解析 city.xml 文档,实现省份及对应城市的联动特效,效果如图所示 实现思路: 创建解析 XML 文档类 ParseXML 和窗体类 ...

  5. dom4j 为生成 XML 的文件添加 xmlns(命名空间) 属性

    dom4j 为生成 XML 的文件添加 xmlns(命名空间) 属性 分类: Java2011-06-03 16:14 976人阅读 评论(0) 收藏 举报 xml扩展语言 今天在开发sitemap地 ...

  6. java中采用dom4j解析xml文件

    一.前言 在最近的开发中用到了dom4j来解析xml文件,以前听说过来解析xml文件的几种标准方式:但是从来的没有应用过来,所以可以在google中搜索dmo4j解析xml文件的方式,学习一下dom4 ...

  7. Python中使用dom模块生成XML文件示例

    在Python中解析XML文件也有Dom和Sax两种方式,这里先介绍如何是使用Dom解析XML,这一篇文章是Dom生成XML文件,下一篇文章再继续介绍Dom解析XML文件. 在生成XML文件中,我们主 ...

  8. 在.net中运用HTMLParser解析网页的原理和方法

    本文介绍了.net 版的一个HTMLParser网页解析开源类库(Winista.HTMLParser)的功能特性.工作原理和使用方法.对于使用.net进行Web信息提取的开发人员进行了一次HTMLP ...

  9. 在java中使用dom4j解析xml

    创建xml文档并输出到文件 import java.io.File; import java.io.FileOutputStream; import org.dom4j.Document; impor ...

随机推荐

  1. poj 1419(图的着色问题,搜索)

    题目链接:http://poj.org/problem?id=1419 思路:只怪数据太弱!直接爆搜,按顺序搜索即可. #include<iostream> #include<cst ...

  2. drupal7使用数据库api db_query需要注意的地方

    写自定义module时候需要从数据库检索数据,用到了数据库的api,用了下面的sql: $record = db_query("SELECT 'sampledate', 'time' FRO ...

  3. js 跳转的几种方法收藏

    history.go(-n) 返回上一页(n 为返回前几页) window.location.reload(); 刷新当前页面 history.go(-1);window.locatoin.reloa ...

  4. 53、Gif 控件GifView 的使用,播放gif图片

    GifView 是一个为了解决android中现在没有直接显示gif的view,只能通过mediaplay来显示这个问题的项目,其用法和 ImageView一样,支持gif图片.可监视GIF是否加载成 ...

  5. fis3解决web网站缓存问题

    为什么使用FIS3 项目上线一段时间后如果更新JS或CSS文件,而客户端已经对该文件缓存过了,那就有可能会无法及时更新而继续采用旧的JS或CSS文件,无法达到想要的效果. 处理类似情况最有效的解决方案 ...

  6. Python 日志模块的定制

    Python标准logging模块中主要分为四大块内容: Logger: 定义应用程序使用的接口 Handler: 将Loggers产生的日志输出到目的地 Filter: 对Loggers产生的日志进 ...

  7. 转载:Eslint 规则说明

    原文: http://blog.csdn.net/helpzp2008/article/details/51507428 ,//禁止使用alert confirm prompt ,//禁止使用数组构造 ...

  8. 160621、Java注解教程及自定义注解

    Java注解提供了关于代码的一些信息,但并不直接作用于它所注解的代码内容.在这个教程当中,我们将学习Java的注解,如何定制注解,注解的使用以及如何通过反射解析注解. Java1.5引入了注解,当前许 ...

  9. Django框架-模板系统

    来看一段代码 def current_datetime(request): now = datetime.datetime.now() html = "<html><bod ...

  10. tf.clip_by_value:将tensor中的0和NONE进行范围限制的函数

    tf.clip_by_value clip_by_value(    t,    clip_value_min,    clip_value_max,    name=None) Defined in ...