采用dom4j解析xml过程

dom4j是一个非常非常优秀的java xml api,具有性能优异、功能强大和极端易用使用的特点,同时它也是一个开放源代码的软件。如今你可以看到越来越多的 java软件都在使用 dom4j来读写 xml,特别值得一提的是连 sun 的 jaxm也在用 dom4j。

如果项目中要添加dom4j类库支持,需要将工具包加载到项目类路径下,或采用maven包管理的话可以在pom.xml里边添加项目包依赖即可,如下:

<dependency>
    <groupId>dom4j</groupId>
      <artifactId>dom4j</artifactId>
      <version>1.6.1</version>
</dependency>

假如给定了一条xml字符串,需要将字符串里边的数据分别提取出来。这种情况在一些标准的api接口里边是很常见的,那么如何对xml字符串进行解析呢?

导入类库包:

import org.dom4j.DocumentHelper;

采用DocumentHelper#parseText()将xml字符串转换为Document对象,如下:

Document document = DocumentHelper.parseText(xmlStr);

假如给定的xml字符串为:

<?xml version="1.0" encoding="UTF-8"?>  
<persons>  
     <person gender="男性">
         <name>张三</name>
         <age>26</age>
         <email>zhangsan@gmail.com</email>
         <englishName>zhangsan</englishName>
         <website>zhangsan.com</website>
     </person>
    <person gender="男性">
        <name>李四</name>
        <age>27</age>
        <email>lisi@gmail.com</email>
        <englishName>lisi</englishName>
        <website>lisi.com</website>
    </person>
    <person gender="男性">
        <name>王五</name>
        <age>27</age>
        <email>wangwu@gmail.com</email>
        <englishName>wangwu</englishName>
        <website>wangwu.com</website>
    </person>
</persons>

解析过程如下:

List<HashMap<String, String>> personList = new ArrayList<HashMap<String, String>>();
try {
    Document document = DocumentHelper.parseText(xmlStr);

    Element rootElement = document.getRootElement();// 获取根节点
    for (Iterator<?> iterator = rootElement.elementIterator(); iterator.hasNext();) {
        Element element = (Element) iterator.next();

        Map<String, String> personMap = new HashMap<String, String>();

        Attribute genderAttr = element.attribute("gender");//获取元素的gender属性对象
        personMap.put("gender", StringUtils.trim(genderAttr.getValue()));// 获取属性对象的值并插入map中,键名为gender

        for (Iterator<?> iterator2 = element.elementIterator(); iterator2.hasNext();) {
            Element element2 = (Element) iterator2.next();

            personMap.put(element2.getName(), element2.getTextTrim());// 将子节点的名称和值分别插入map中
        }
        personList.add(personMap);//将map插入list中
    }
} catch (DocumentException e) {
    e.printStackTrace();
}
System.out.println(personList);

打印结果如下:

[{englishName=zhangsan, website=zhangsan.com, email=zhangsan@gmail.com, age=26, name=张三, gender=男性}, {englishName=lisi, website=lisi.com, email=lisi@gmail.com, age=27, name=李四, gender=男性}, {englishName=wangwu, website=wangwu.com, email=wangwu@gmail.com, age=27, name=王五, gender=男性}]

  • 3
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 4
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值