dom4j解析和生成XML文档

  1. 解析XML的两种方法
package cnslp.dom4j.com;
import java.io.File;
import java.util.Iterator;

import org.dom4j.Attribute;
import org.dom4j.Document;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;
/**
 * Created by cnslp on 2017/5/12 0012.
 * 解析XML文档的两种方法
 */

public class Demo {
    public static void main(String[] args) throws Exception {
        SAXReader reader = new SAXReader();//创建SAXReader读取器,专门用于读取xml
        File file = new File("books.xml");
        Document document = reader.read(file);
        Element root = document.getRootElement();
        //迭代方法
        Iterator it = root.elementIterator();
        while (it.hasNext()) {
            Element element = (Element) it.next();

           Iterator attrIt = element.attributeIterator();//迭代元素属性
           while (attrIt.hasNext()) {
            Attribute a  = (Attribute) attrIt.next();
            System.out.println(a.getValue());
           }

           Iterator eleIt = element.elementIterator();//迭代子元素
           while (eleIt.hasNext()) {
            Element e = (Element) eleIt.next();
            System.out.println(e.getName() + ": " + e.getText());
           }
           System.out.println();
        }
    }

    /*   //List方法
        //根据saxReader的read重写方法可知,既可以通过inputStream输入流来读取,也可以通过file对象来读取
        //Document document = saxReader.read(inputStream);

        List<Element> childElements = root.elements();
        for (Element child : childElements) {
            System.out.println("element name:"+ child.getName());
            //未知属性名情况下
            List<Attribute> attributeList = child.attributes();//获取元素的所有属性
           for (Attribute attr : attributeList) {
            System.out.println("name:"+attr.getName() + ": " + attr.getValue());
           }
           //已知属性名情况下
           //System.out.println("id: " + child.attributeValue("id"));

            //未知子元素名情况下
           List<Element> elementList = child.elements();
           for (Element ele : elementList) {
            System.out.println(ele.getName() + ": " + ele.getText());
           }
           System.out.println();

            //已知子元素名的情况下
           // System.out.println("title" + child.elementText("title"));
           // System.out.println("author" + child.elementText("author"));

            System.out.println();
        }
    }*/
}

2.生成XML文档

package cnslp.dom4j.com;
import org.dom4j.*;
import org.dom4j.io.OutputFormat;
import org.dom4j.io.XMLWriter;

import java.io.File;
import java.io.FileOutputStream;

/**
 * Created by cnslp on 2017/5/12 0012.
 */
public class OutXML {
    public static void main(String[] args) throws Exception {
        Document doc = DocumentHelper.createDocument();
        //增加根节点
        Element books = doc.addElement("books");
        //增加子元素
        Element book1 = books.addElement("book");
        Element title1 = book1.addElement("title");
        Element author1 = book1.addElement("author");

        Element book2 = books.addElement("book");
        Element title2 = book2.addElement("title");
        Element author2 = book2.addElement("author");

        //为子节点添加属性
        book1.addAttribute("id", "001");
        //为元素添加内容
        title1.setText("Harry Potter");
        author1.setText("J K. Rowling");

        book2.addAttribute("id", "002");
        title2.setText("Learning XML");
        author2.setText("Erik T. Ray");

        //实例化输出格式对象
        OutputFormat format = OutputFormat.createPrettyPrint();
        //设置输出编码
        format.setEncoding("UTF-8");
        //创建需要写入的File对象
        File file = new File("D:" + File.separator + "books.xml");
        //生成XMLWriter对象,构造函数中的参数为需要输出的文件流和格式
        XMLWriter writer = new XMLWriter(new FileOutputStream(file), format);
        //开始写入,write方法中包含上面创建的Document对象
        writer.write(doc);
    }

}
时间: 2024-08-27 10:16:04

dom4j解析和生成XML文档的相关文章

Dom4j解析语音数据XML文档(注意ArrayList多次添加对象,会导致覆盖之前的对象)

今天做的一个用dom4j解析声音文本的xml文档时,我用ArrayList来存储每一个Item的信息,要注意ArrayList多次添加对象,会导致覆盖之前的对象:解决方案是在最后将对象添加入ArrayLis时先new 一个对象,然后将之前那个对象的属性set到新的对象中,之后在加入到 ArrayList,就不会出错了. package parseXML; import org.dom4j.Attribute;import org.dom4j.Document;import org.dom4j.E

当xml中存在命名空间,dom4j解析以及写入xml文档时的乱码问题

最近公司项目开发中需要通过前台用户界面进行客户业务系统的部署(提供界面化操作,减少运维工作的难度),通过修改web.xml进行设置各个项目不同的信息配置. 开发过程中遇到2种问题,同时将解决方案备注上,以方便日后查看. 问题一:当xml中存在命名空间,三种处理办法(dom4j) 问题二:文件保存之后总是提示中文乱码问题 针对上面2个问题的解决方案进行汇总,解决方法主要还是来自于其他网络同行的博客. 第一个 问题主要参照 博客http://blog.sina.com.cn/s/blog_5cef6

生成XML文档

JAVA操作XML文档主要有四种方式,分别是DOM.SAX.JDOM和DOM4J,DOM和SAX是官方提供的,而JDOM和DOM4J则是引用第三方库的,其中用的最多的是DOM4J方式.运行效率和内存使用方面最优的是SAX,但是由于SAX是基于事件的方式,所以SAX无法在编写XML的过程中对已编写内容进行修改,但对于不用进行频繁修改的需求,还是应该选择使用SAX. 现在来生成这样的一份XML文档,文档内容如下: <?xml version="1.0" encoding="

(九)生成XML文档流程

一:DOM方法生成XML 步骤: 1:创建DocumentBuilder:DocumentBuilder builder=new DocumentBuilder(); 2:创建dom对象:Document dom=builder.newDocument(); 3:创建dom中元素:Element element=dom.createElement("元素名"); 4:向元素添加子节点:element.appendChild(childElement);(dom树就是通过不停append

ASP.NET 动态查找数据 并且生成xml文档 同时使用xslt转换为xhtml

前言 xsl是一门标签解析语言,很适合做动态网页的前台标签 www.bamn.cn 1 首先是aspx页面 添加一个输入框 按钮 还有一个用来显示解析后的xhtml代码的控件 <form id="form1" runat="server"> <div> <asp:TextBox ID="TextBox1" runat="server" TextMode="MultiLine"

6-3 如何解析简单的XML文档

元素节点.元素树 >>> from xml.etree.ElementTree import parse >>> help(parse) Help on function parse in module xml.etree.ElementTree: parse(source, parser=None) help(parse) >>> f = open(r'C:\视频\python高效实践技巧笔记\6数据编码与处理相关话题\linker_log.xml'

通过 JDOM 方式生成 XML 文档

1.引入jdom jar包 2.代码 Element ele = new Element("tree"); ele.setAttribute("id","0"); Document document = new Document(ele); Element e1 = new Element("name"); e1.setText("名称"); ele.addContent(e1); // Format fo

WebService生成XML文档时出错。不应是类型XXXX。使用XmlInclude或SoapInclude属性静态指定非已知的类型。

情况是SingleRoom和DoubleRoom是Room类的子类.在WebService中有一个方法是返回Room类. public Room Get(int roomId) { return Room.Get(roomId); } XmlSerializer在序列化时只能识别父类,而不能识别子类,所以导致序列化的错误.需要将[XmlInclude(typeof(SingleRoom))]和[XmlInclude(typeof(DoubleRoom))]同时加到WebService中. [Xm

四种生成和解析XML文档的方法详解(介绍+优缺点比较+示例)

四种生成和解析XML文档的方法详解(介绍+优缺点比较+示例) 众所周知,现在解析XML的方法越来越多,但主流的方法也就四种,即:DOM.SAX.JDOM和DOM4J 下面首先给出这四种方法的jar包下载地址 DOM:在现在的Java JDK里都自带了,在xml-apis.jar包里 SAX:http://sourceforge.net/projects/sax/ JDOM:http://jdom.org/downloads/index.html DOM4J:http://sourceforge.