区间字符串生成

------------------------------------------Controller

/**
 * @param section 区间字符串
 * @description 费率区间生成
 */
@ApiOperation("区间生成")
@PostMapping(value = "/getSection")
public R getSection(@RequestBody String[] section) {
    return productService.getSection(section);
}

-----------------------------------------Service

/**
 * 费率区间生成
 * @param section 区间字符串
 */
R getSection(String[] section);

-------------------------------------------ServiceImpl

 /**
 * @param section 区间字符串
 * @description 费率区间生成
 * @return: R
 */
@Override
public R getSection(String[] section) {
    List<ProductRateDetailInfoVO> list = new ArrayList<>();

    for (String s : section) {
        if (!ReUtil.isMatch("^[1-9]\\d*$", s)) {
            return R.warning("请输入正整数,不可包含特殊字符");
        }
    }
    for (int i = 0; i < section.length - 1; i++) {
        if (Long.parseLong(section[i]) >= Long.parseLong(section[i + 1])) {
            return R.warning("区间格式错误,应从小到大排序");
        }
    }

    ProductRateDetailInfoVO pmsFeeRateDetail = new ProductRateDetailInfoVO();
    // 序号
    pmsFeeRateDetail.setSeq(1);
    // 区间下限
    pmsFeeRateDetail.setMin(0L);
    // 区间上限
    pmsFeeRateDetail.setMax(Long.parseLong(section[0]));
    pmsFeeRateDetail.setSection("M<" + Long.parseLong(section[0]));
    list.add(pmsFeeRateDetail);
    for (int i = 1; i < section.length; i++) {
        ProductRateDetailInfoVO feeRateDetail = new ProductRateDetailInfoVO();
        // 序号
        feeRateDetail.setSeq(i + 1);
        // 区间下限
        feeRateDetail.setMin(Long.parseLong(section[i - 1]));
        // 区间上限
        feeRateDetail.setMax(Long.parseLong(section[i]));
        feeRateDetail.setSection(section[i - 1] + "<=M<" + section[i]);
        list.add(feeRateDetail);
    }
    ProductRateDetailInfoVO productRateDetailEnd = new ProductRateDetailInfoVO();
    productRateDetailEnd.setSeq(section.length + 1);
    // 无限大的数据
    productRateDetailEnd.setMin(999999999L);
    productRateDetailEnd.setMax(Long.parseLong(section[section.length - 1]));
    productRateDetailEnd.setSection(section[section.length - 1] + "<=M");
    list.add(productRateDetailEnd);
    return R.ok().data(list);
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值