Java 中解析 xml 格式字符串的数据

解析 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;
    }


}
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值