解析xml字符串小util类

可以根据兄弟节点的名称+值,来获取需要查找的节点的值

也可直接查找所要查找的节点的值

maven节点

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

 


import java.util.Iterator;
import java.util.List;

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

/**
 * @description 解析xml字符串
 */
public class xmlUtil {
	public static void main(String[] args) throws DocumentException {
		String xmlString = "<?xml version=\"1.0\" encoding=\"utf-8\"?>" + "" 
	+ "<NewDataSet>" 
				+ "  <Table>" + ""
				+ "    <Playdate>20200322</Playdate>" 
				+ "    <PlaySeq>009</PlaySeq>"
				+ "    <OnlineDate>20200315</OnlineDate>"
				+ "    <NoOfTime>1</NoOfTime>\r\n" 
				+ "    <SeatYN>N</SeatYN>\r\n"
				+ "    <BalanceSeatYN>N</BalanceSeatYN>" 
				+ "    <CancelableDate>202003211100</CancelableDate>"
				+ "<PlayTimeValue>1700</PlayTimeValue>" 
				+ "" + "" 
				+ "  </Table>\r\n" 
				+ "  <Table>" + "" 
				+ "    "
				+ "    <PlaySeq>001</PlaySeq>" 
				+ "    <PlayTime>" 
				+ "		<Playdate>20200322</Playdate>"
				+ "		<PlaySeq>003</PlaySeq>" 
				+ "		</PlayTime> " 
				+ "    <OnlineDate>20200315</OnlineDate>"
				+ "    <NoOfTime>1</NoOfTime>\r\n"
				+ "    <SeatYN>N</SeatYN>\r\n"
				+ "    <BalanceSeatYN>N</BalanceSeatYN>" 
				+ "    <CancelableDate>202003211100</CancelableDate>"
				+ "<PlayTimeValue>17010</PlayTimeValue>" 
				+ "  </Table>\r\n" 
				+ "</NewDataSet>\r\n" + "";
		Document doc = DocumentHelper.parseText(xmlString);
		Element rootElt = doc.getRootElement();// .elementText("PlayTimeValue")
	
		// 根节点下面的节点
		
		getXml(rootElt.elements(), "Playdate", "20200322", "PlaySeq");

		// readStringXml(xmlString);
	}
	/**
	 * le:根节点下面的节点们   
	 * findEle  兄弟节点的名称
	 * findeValue 兄弟节点值
	 * wantName  要找的节点的名称
	 */
	public static void getXml(List<Element> le, String findEle, String findeValue, String wantName) {
		Element element = null;
		for (int i = 0; i < le.size(); i++) {
			element = le.get(i);
			if (findEle!=null &&findeValue!=null ) {
				if(element.getName().equals(findEle) && element.getText().equals(findeValue)) {
					System.out.println(element.getParent().element(wantName).getText());
				}
			}else {//当兄弟节点为null的时候
				if(element.getName().equals(wantName)&&findEle==null) {
					System.out.println("查找到所需要的节点了"+element.getText());
				}
			}
			if (element.elements().size() > 0) {
				getXml(element.elements(), findEle, findeValue, wantName);
			}

		}

	}

}

 

可以使用dom4j封装的工具来实现Java解析XML字符串转Map的功能。具体步骤如下: 1.引入dom4j和jaxen的依赖包。 2.编写XmlUtils工具,实现xmlParser方法,该方法接收两个参数,一个是xml字符串,一个是根节点名称,返回一个Map型的结果。 ```java 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.Element; import org.dom4j.io.SAXReader; public class XmlUtils { public static Map<String, Object> xmlParser(String xml, String rootName) throws DocumentException { Map<String, Object> map = new HashMap<String, Object>(); SAXReader reader = new SAXReader(); Document document = reader.read(new ByteArrayInputStream(xml.getBytes())); Element root = document.getRootElement(); if (root.getName().equals(rootName)) { map.put(root.getName(), parseElement(root)); } return map; } private static Map<String, Object> parseElement(Element element) { Map<String, Object> map = new HashMap<String, Object>(); List<Attribute> attributes = element.attributes(); for (Attribute attribute : attributes) { map.put("->" + element.getName() + "=>" + attribute.getName(), attribute.getValue()); } List<Element> elements = element.elements(); if (elements.size() == 0) { map.put("->" + element.getName(), element.getTextTrim()); } else { for (Element ele : elements) { if (ele.elements().size() == 0) { map.put("->" + element.getName() + "->" + ele.getName(), ele.getTextTrim()); } else { map.put("->" + element.getName() + "->" + ele.getName(), parseElement(ele)); } } } return map; } } ``` 3.在需要解析XML字符串的地方,调用xmlParser方法即可。 ```java String xml = "<root><name>张三</name><age>18</age><address><province>广东</province><city>深圳</city></address></root>"; Map<String, Object> map = XmlUtils.xmlParser(xml, "root"); System.out.println(map); ``` 输出结果为: ```java {root={->name=张三, ->age=18, ->address={->province=广东, ->city=深圳}}} ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值