使用dom4j来解析xml文件:
首先需要下载dom4j,去官网下载最新版本
下载之后,我们先要在ide里创建一个xml用来提取数据
以下是用来解析的示例H.xml文件:
<?xml version="1.0" encoding="utf-8"?>
<list>
<foo id="a">
<name>Aoo</name>
<desc>Ao</desc>
</foo>
<foo id="b">
<name>Boo</name>
<desc>Bo</desc>
</foo>
</list>
在ide中导入dom4j的包,新创建一个java文件,内容如下:
import org.dom4j.Attribute;
import org.dom4j.Document;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;
import java.util.Iterator;
public class parseXML {
public static void main(String[] args) throws Exception{
//这里可以获得一个document的对象,可以通过document对象获取xml内部的资源
SAXReader reader = new SAXReader();
//这里指定xml所在地路径
Document document = reader.read("H.xml");
//获取根节点和根节点的名字
Element rootElement = document.getRootElement();
System.out.println(rootElement.getName());
//每个节点都可以获得一个迭代器,可以是子节点迭代器(不包括孙子节点),也可以是属性迭代器,两者都可以实现资源的遍历
//方法可以返回指定元素的迭代器,只要传入字符串名称即可
Iterator<Element> elementIterator = rootElement.elementIterator();
//以下为输出子节点和子节点的属性列表
while(elementIterator.hasNext()){
Element next = elementIterator.next();
//获得子节点名称
System.out.println(next.getName());
Iterator<Attribute> attributeIterator = next.attributeIterator();
while(attributeIterator.hasNext()){
Attribute next1 = attributeIterator.next();
//获得属性的名称和值
System.out.println(next1.getName()+":"+next1.getValue());
}
//如果选中的元素中有文本内容,可以使用getText()方法获得
}
}
}
使用dom4j创建xml文件:
使用DocumentHelper.createDocument();可以返回一个document对象,可以把它看作一个空的xml文档,可以在里面添加子元素和属性:
//给document对象添加一个子节点,名称为root,返回子节点的地址给Element,通过Element可以对子节点进行操作,
Element element = document.addElement("root");
//给节点添加属性:"属性名","属性值"
element.addAttribute("A","a");
//给节点添加文本
element.addText("root");
//保存xml(只有这一步会生成xml文件)
//输入文件名称,包括xml后缀
FileWriter writer = new FileWriter("foo.xml");
//调用document的write保存xml文件
document.write(writer);
//最后记得关闭FileWriter
writer.close();