dom4j创建和解析xml文件实例


/**
 * dom4j创建和解析xml文件
 * 注意编码格式
 * 默认是GBK,当改为其他时,注意输出编码格式,与xml文件编码格式一致。否则解析报错。
 * 还有创建元素的属性 
 * 
 */
public class XMLDemo {

public static void main(String[] args) throws Exception {
String file = "e://xml//maiku.xml";
createXml(file);
parseXml(file);
}

/**

*/
private static void createXml(String file) {
Document document = DocumentHelper.createDocument();
Element root = document.addElement("maiku");
Element element = root.addElement("私人笔记");
root.addElement("共享笔记");
Element dream = element.addElement("梦想");
dream.addAttribute("time", "2month");
dream.setText("旅行");
Element reading = element.addElement("阅读");
reading.addElement("小说").setText("琅琊榜");
reading.addElement("电影").setText("奇幻人生");
try {
OutputFormat format =new OutputFormat(" ",true);
/**
* 次处编码默认为GBK,如果设置为utf-8,记得将输出流也按照utf-8的格式转码,否则解析的时候会出错。
*/
format.setEncoding("utf-8");
OutputStreamWriter os = new OutputStreamWriter(new FileOutputStream(file),"utf-8");
XMLWriter xMLWriter = new XMLWriter(os,format);//设置格式
// Writer writer = new FileWriter(file);
// XMLWriter xMLWriter = new XMLWriter();
// xMLWriter.setWriter(writer);
xMLWriter.write(document);
xMLWriter.close();
} catch (IOException e) {
e.printStackTrace();
}
}

/**

* @param file
*/
private static void parseXml(String file) {
SAXReader sAXReader = new SAXReader();
try {
Document document = sAXReader.read(new File(file));
Element root = document.getRootElement();
Element element = root.element("私人笔记");
Element dream = element.element("梦想");
System.out.println(dream.getText());
System.out.println(dream.attribute("time").getName()+":"+dream.attribute("time").getText());//属性名和值
Element reading = element.element("阅读");
Element novel = reading.element("小说");
System.out.println(novel.getText());
Element movie = reading.element("电影");
System.out.println(movie.getText());
} catch (DocumentException e) {
e.printStackTrace();
}
}


}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个简单的dom4j解析xml文件的示例: 假设我们有一个名为“person.xml”的xml文件,内容如下: ``` <?xml version="1.0" encoding="UTF-8"?> <person> <name>张三</name> <age>28</age> <gender>男</gender> <address>北京市海淀区</address> </person> ``` 我们可以使用dom4j库来解析这个xml文件并读取其中的数据。下面是示例代码: ```java import java.io.File; import java.util.Iterator; import org.dom4j.Document; import org.dom4j.Element; import org.dom4j.io.SAXReader; public class Dom4jDemo { public static void main(String[] args) throws Exception { // 创建解析器 SAXReader reader = new SAXReader(); // 读取xml文件 Document document = reader.read(new File("person.xml")); // 获取根元素 Element root = document.getRootElement(); // 获取子元素 Iterator<Element> it = root.elementIterator(); while (it.hasNext()) { Element element = it.next(); String name = element.getName(); String value = element.getText(); System.out.println(name + ": " + value); } } } ``` 输出结果如下: ``` name: 张三 age: 28 gender: 男 address: 北京市海淀区 ``` 在这个示例中,我们首先创建了一个SAXReader对象来解析xml文件。然后,我们使用read()方法读取xml文件并返回一个Document对象。接下来,我们获取根元素和其子元素,并使用elementIterator()方法遍历所有子元素。对于每个子元素,我们使用getName()方法获取其标签名,使用getText()方法获取其文本内容,并将它们打印到控制台上。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值