解析 xml 格式中的字符串数据
相信有很多小伙伴经历过接口返回的数据是在一段 xml 字符串格式的数据里,那么我们可用什么最快最便捷的方法取到里面的数据勒?
下面这里是一个xml 格式的是实例
这里是 xml 里面有多个,如果是单个那就直接解析就行
import cn.hutool.core.util.XmlUtil;
import com.ruoyi.web.controller.tool.TestAA;
import org.w3c.dom.Document;
import javax.xml.xpath.XPathConstants;
import java.util.ArrayList;
import java.util.List;
public class aaa {
public static void main(String[] args) throws Exception {
String str = "<?xml version=\"1.0\" encoding=\"UTF-8\" standalone=\"yes\"?>\n" +
"<root>\n" +
" <head>\n" +
" <H />\n" +
" <line>\n" +
" <L>\n" +
" <LINE_NUM>491</LINE_NUM>\n" +
" <COST_CODE>101160404</COST_CODE>\n" +
" <MA_ACCOUNT>66011402</MA_ACCOUNT>\n" +
" <MA_NAME>伙食补贴</MA_NAME>\n" +
" <MA_PROJECT>101400000004</MA_PROJECT>\n" +
" <AMOUNT>400</AMOUNT>\n" +
" <OPERATOR_NAME></OPERATOR_NAME>\n" +
" <LY></LY>\n" +
" <FYCDBM>101160404</FYCDBM>\n" +
" </L>\n" +
" <L>\n" +
" <LINE_NUM>656</LINE_NUM>\n" +
" <COST_CODE>101160404</COST_CODE>\n" +
" <MA_ACCOUNT>66011404</MA_ACCOUNT>\n" +
" <MA_NAME>绩效工资</MA_NAME>\n" +
" <MA_PROJECT>101400000004</MA_PROJECT>\n" +
" <AMOUNT>2800</AMOUNT>\n" +
" <OPERATOR_NAME></OPERATOR_NAME>\n" +
" <LY></LY>\n" +
" <FYCDBM>101160404</FYCDBM>\n" +
" </L>\n" +
" </line>\n" +
" </head>\n" +
"</root>";
//进行截取, 得到一个集合
List<String> list = getChildMsgByParent(str, "<L>", "</L>");
for (String s : list) {
//System.out.println(s);
//转换成docment对象 利用 hutool 类的方法
//如果 xml 里面是单个数据,不用进行分割,直接调到这一步
Document docResult = XmlUtil.readXML(s);
Object value = XmlUtil.getByXPath("//L/LINE_DESCRIPTION", docResult, XPathConstants.STRING);
System.out.println(value);
Object BATCH = XmlUtil.getByXPath("//L/BATCH", docResult, XPathConstants.STRING);
System.out.println(BATCH);
Object LINE_NUM = XmlUtil.getByXPath("//L/LINE_NUM", docResult, XPathConstants.STRING);
System.out.println(LINE_NUM);
TestAA testAA = new TestAA();
testAA.setLINE_DESCRIPTION((String) value);
System.out.println(testAA);
}
}
/**
* 截取分割方法
* 通过这个方法把 xml 的字符串头部尾部截取掉
* @param info
* @param begin
* @param end
* @return
*/
public static List<String> getChildMsgByParent(String info, String begin, String end){
//通过起始字符拆分成数组
String[] split = info.split(begin);
List<String> list = new ArrayList<>();
//遍历,从第二个元素开始取值(第一个元素为无效元素)
for (int i = 1; i < split.length; i++) {
String str = split[i].substring(0,split[i].lastIndexOf(end)+end.length());
if (str.length() > end.length()) {
list.add(begin+str);
}
}
return list;
}
}