dom4j的读写xml文件,读写xml字符串

百度了一些博客,大同小异,在选取jar包工具的时候大概看了下,大抵是jdom原始,dom4j优秀。于是做了些练习。

参考:http://www.cnblogs.com/mengdd/archive/2013/06/05/3119927.html

  1 package com.test.xml;
  2 
  3 import java.io.File;
  4 import java.io.FileOutputStream;
  5 import java.io.IOException;
  6 import java.util.List;
  7 import java.util.Random;
  8 
  9 import org.dom4j.Document;
 10 import org.dom4j.DocumentException;
 11 import org.dom4j.DocumentHelper;
 12 import org.dom4j.Element;
 13 import org.dom4j.io.OutputFormat;
 14 import org.dom4j.io.SAXReader;
 15 import org.dom4j.io.XMLWriter;
 16 
 17 /**
 18 * @ClassName: TestDom4j 
 19 * @Description:dom4j练习xml的读写 
 20 * @author mrf
 21 * @date 2015-11-11 下午02:25:20 
 22 *
 23  */
 24 public class TestDom4j {
 25     
 26     /**
 27     * @Title: read 
 28     * @Description:读取xml文件 
 29     * @param @param path    参数
 30     * @return void    返回类型
 31      * @throws DocumentException 
 32      */
 33     public static void read(String path) throws DocumentException{
 34         SAXReader saxReader = new SAXReader();
 35         Document doc = saxReader.read(new File(path));
 36         //获取根元素
 37         Element root = doc.getRootElement();
 38         System.out.println(root.getName()+root.attributeValue("name"));
 39         //获取子元素
 40         @SuppressWarnings("unchecked")
 41         List<Element> grades = root.elements();
 42         if(!grades.isEmpty()){
 43             for (int i = 0; i < grades.size(); i++) {
 44                 Element element = grades.get(i);
 45                 System.out.println(element.getName()+element.attributeValue("name"));
 46                 @SuppressWarnings("unchecked")
 47                 List<Element> classes = element.elements();
 48                 if(classes.size()>0){
 49                     for (int j = 0; j < classes.size(); j++) {
 50                         Element cls = classes.get(j);
 51                         @SuppressWarnings("unchecked")
 52                         List<Element> stus = cls.elements();
 53                         if(!stus.isEmpty()){
 54                             for (int k = 0; k < stus.size(); k++) {
 55                                 Element stu = stus.get(k);
 56                                 System.out.println(stu.getName()+stu.attributeValue("name"));
 57                                 
 58                                 //以下证明elements方法返回值不会为null,另查看源码发现也是直接创建list
 59 //                                List list = stu.elements();
 60 //                                System.out.println(list==null);
 61 //                                System.out.println(list.size());
 62 //                                System.out.println(list);
 63                             }
 64                         }
 65                         
 66                     }
 67                 }
 68             }
 69         }
 70     }
 71     
 72     /**
 73     * @Title: getRandoStr 
 74     * @Description:获取一个随机字符串 
 75     * @param @param len
 76     * @param @return    参数
 77     * @return String    返回类型
 78      */
 79     public static String getRandoStr(int len){
 80         String base = "abcdefghijklmnopqrstuvwxyz1234567890";
 81         Random random = new Random();
 82         StringBuilder sb = new StringBuilder();
 83         for (int i = 0; i < len; i++) {
 84             sb.append(base.charAt(random.nextInt(base.length())));
 85         }
 86         
 87         return sb.toString();
 88     }
 89     
 90     /**
 91     * @Title: write 
 92     * @Description: 测试写一个school文件
 93     * @param @throws IOException    参数
 94     * @return void    返回类型
 95      */
 96     public static void write(String path) throws IOException{
 97         //创建doc文档
 98         Document doc = DocumentHelper.createDocument();
 99         Element root = DocumentHelper.createElement("school");
100         //设置根元素
101         doc.setRootElement(root);
102         //添加属性
103         root.addAttribute("name","实验中学");
104         root.addAttribute("position","河北石家庄");
105         
106         Element grade = root.addElement("grade");
107         grade.addAttribute("name", "年级");
108         grade.addAttribute("size", "1");
109         Element cls = grade.addElement("class");
110         cls.addAttribute("name", "班级");
111         cls.addAttribute("size", "70");
112         Element stu = cls.addElement("student");
113         stu.addAttribute("name", getRandoStr(4));
114         stu.addAttribute("age", 13+"");
115         stu.addAttribute("sex", new Random().nextInt(2)+"");
116         stu.setText("学生");
117         
118 //        //添加三个子节点初一初二初三
119 //        for (int i = 1; i < 4; i++) {
120 //            Element grade = root.addElement("grade");
121 //            grade.addAttribute("name", "grade_"+i);
122 //            grade.addAttribute("size", "20");
123 //            //添加20个班级
124 //            for (int j = 1; j < 21; j++) {
125 //                Element cls = grade.addElement("class");
126 //                cls.addAttribute("name", "grade_"+i+"_class_"+j);
127 //                cls.addAttribute("size", "70");
128 //                //添加70个学生
129 //                for (int k = 1; k < 71; k++) {
130 //                    Element stu = cls.addElement("student");
131 //                    stu.addAttribute("name", getRandoStr(4));
132 //                    stu.addAttribute("age", 12+i+"");
133 //                    stu.addAttribute("sex", new Random().nextInt(2)+"");
134 //                    stu.setText("学生");
135 //                }
136 //            }
137 //        }
138         
139         
140         //输出
141         //控制台
142         new XMLWriter().write(doc);
143         
144         //文件
145         //格式 -缩进\t true表示换行
146         OutputFormat format = new OutputFormat("\t",true);
147         XMLWriter writer = new XMLWriter(new FileOutputStream(path),format);
148         writer.write(doc);
149         writer.flush();
150         writer.close();
151         
152     }
153     
154     //解析xml字符串
155     public static Document parseStr(String xmlStr) throws DocumentException{
156         Document doc = DocumentHelper.parseText(xmlStr);
157         return doc;
158     }
159     
160     public static void main(String[] args) throws IOException, DocumentException {
161 //        write("src/main/java/com/test/xml/school.xml");
162         
163         read("src/main/java/com/test/xml/school.xml");
164         
165     }
166 
167 }

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏Java成神之路

Java企业微信开发_08_素材管理之下载微信临时素材到本地服务器

请求地址:https://qyapi.weixin.qq.com/cgi-bin/media/get?access_token=ACCESS_TOKEN&med...

632
来自专栏斑斓

AKKA中的事件流

在《企业应用集成模式》一书中,定义了许多与消息处理有关的模式,其中运用最为广泛的模式为Publisher-Subscriber模式,尤其是在异步处理场景下。 基...

3354
来自专栏码匠的流水账

tomcat如何关闭response的outputStream

在写文件下载的时候,遇到了一个问题,就是这个ServletOutputStream到底要不要自己flush以及close。这里以tomcat容易为例,解读一下。

641
来自专栏Android 研究

Android插件化基础2----理解Context

为了让大家在后面更好的理解插件化的内容,我们本篇文章围绕Context(基于Android API 24)进行讲解,主要内容如下:

813
来自专栏圣杰的专栏

事件总线知多少(2)

源码路径:Github-EventBus 事件总线知多少(1) 事件总线知多少(2) 1.引言 之前的一篇文章事件总线知多少(1),介绍了什么是事件总线...

2017
来自专栏恰同学骚年

ASP.Net请求处理机制初步探索之旅 - Part 5 ASP.Net MVC请求处理流程

开篇:上一篇我们了解了在WebForm模式下一个Page页面的生命周期,它经历了初始化Init、加载Load以及呈现Render三个重要阶段,其中构造了页面控件...

803
来自专栏马洪彪

Java设计模式(六)Adapter适配器模式

一、场景描述 “仪器数据采集器”包含采集数据以及发送数据给服务器两行为,则可定义“仪器数据采集器”接口,定义两方法“采集数据capture”和“发送数据send...

3335
来自专栏Java成神之路

Java微信开发_Exception_01_The type org.xmlpull.v1.XmlPullParser cannot be resolved. It is indirectly ref

这个异常是在做微信开发时出现的,在引入了XStream的jar包之后,还是出现了如下错误信息:

583
来自专栏Java与Android技术栈

Cold Observable 和 Hot Observable

Hot Observable 无论有没有 Subscriber 订阅,事件始终都会发生。当 Hot Observable 有多个订阅者时,Hot Observa...

812
来自专栏向治洪

picasso图片缓存框架

picasso是Square公司开源的一个Android图形缓存库,地址http://square.github.io/picasso/,可以实现图片下载和缓...

1818

扫描关注云+社区