java解析xml通用版

1 篇文章 0 订阅

       平时接触xml比较多,解析的时候通常会涉及到xml的节点值,这样每次都需要写一遍类似的代码,比较繁琐。下面这段程序可以适用于各种xml,通过递归将里面的元素和属性封装成一个Map返回。不过有个比较明显的缺点是当xml里面的元素名或者属性名重复时,后面的会将前面的覆盖掉。

 

import java.util.HashMap;
import java.util.Iterator;
import java.util.List;
import java.util.Map;

import org.dom4j.Attribute;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.DocumentHelper;
import org.dom4j.Element;

public class XmlUtil {
	/**
	 * 传入一个xml格式的字符串,返回map,适用于无相同的节点时
	 * 
	 * @param xml
	 * @return
	 * @throws DocumentException
	 */
	public static Map<String, String> getNodeData(String xml)
			throws DocumentException {
		Map<String, String> resultMap = new HashMap<String, String>();
		Document doc;
		doc = DocumentHelper.parseText(xml);
		Element elem = doc.getRootElement();
		return getElementList(elem, resultMap);
	}

	/**
	 * 递归遍历方法
	 * 
	 * @param element
	 */
	public static Map<String, String> getElementList(Element element,
			Map<String, String> resultMap) {
		List elements = element.elements();
		if (elements.size() == 0) {
			// 没有子元素
			resultMap.put(element.getName(), element.getTextTrim());
			// 获取属性值
			List arrtList = element.attributes();
			for (int i = 0; i < arrtList.size(); i++) {
				Attribute attr = (Attribute) arrtList.get(i);
				resultMap.put(attr.getName(), attr.getValue().trim());
			}
		} else {
			// 有子元素
			for (Iterator it = elements.iterator(); it.hasNext();) {
				Element elem = (Element) it.next();
				// 递归遍历
				getElementList(elem, resultMap);
			}
		}
		return resultMap;
	}
}

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值