java 解析xml dom4j_在java中使用dom4j解析xml

创建xml文档并输出到文件

import java.io.File;

import java.io.FileOutputStream;

import org.dom4j.Document;

import org.dom4j.DocumentHelper;

import org.dom4j.Element;

import org.dom4j.io.OutputFormat;

import org.dom4j.io.XMLWriter;

public class Demo {

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);

}

}

运行后会在D盘下生成一个books.xml

41db3d4182c6d5c851786ff83ce822e7.png

使用Iterator迭代器的方式来解析xml

xml文档如下:

Harry Potter

J K. Rowling

Learning XML

Erik T. Ray

importjava.io.File;importjava.util.Iterator;importorg.dom4j.Attribute;importorg.dom4j.Document;importorg.dom4j.Element;importorg.dom4j.io.SAXReader;public classDemo {public static void main(String[] args) throwsException {

SAXReader reader= newSAXReader();

Document document= reader.read(new File("books.xml"));

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());

}*/

//已知属性名称情况下

System.out.println("id: " + element.attributeValue("id"));//未知元素名情况下

/*Iterator eleIt = element.elementIterator();

while (eleIt.hasNext()) {

Element e = (Element) eleIt.next();

System.out.println(e.getName() + ": " + e.getText());

}

System.out.println();*/

//已知元素名情况下

System.out.println("title: " + element.elementText("title"));

System.out.println("author: " + element.elementText("author"));

System.out.println();

}

}

}

运行结果:

bdaf20a09fc49f3696f70e165db8fb3e.png

用List列表的方式来解析xml

importjava.io.File;importjava.util.List;importorg.dom4j.Attribute;importorg.dom4j.Document;importorg.dom4j.Element;importorg.dom4j.io.SAXReader;public classDemo {public static void main(String[] args) throwsException {

SAXReader reader= newSAXReader();

File file= new File("books.xml");

Document document=reader.read(file);

Element root=document.getRootElement();

List childElements =root.elements();for(Element child : childElements) {//未知属性名情况下

/*List attributeList = child.attributes();

for (Attribute attr : attributeList) {

System.out.println(attr.getName() + ": " + attr.getValue());

}*/

//已知属性名情况下

System.out.println("id: " + child.attributeValue("id"));//未知子元素名情况下

/*List 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();

}

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值