使用正则表达式,表达数字的比较运算符

需求:使用正则表达式去匹配数字的比较运算符

例:

  • 过滤出所有小于18的数字字符串:
  • 正则表达式为:
^18\.\d*[1-9]+\d*$|^[1-9]\d{2,}(?:|\.\d+)$|^[2-9]\d{1}(?:|\.\d+)$|^1[9-9](?:|\.\d+)$
import cn.hutool.core.util.NumberUtil;
import cn.hutool.core.util.StrUtil;

/**
 * 根据输入数字,转换比较运算符的正则表达式
 *
 * 例:
 *  < 55.06   正则表达式为:^-\d+(?:|\.\d+)$|^(?:|[0-4])\d{1,1}(?:|\.\d+)$|^5[0-4](?:|\.\d+)$|^55(?:|\.[0]+)$|^55\.0(?:|[0-5]\d*)$
 *  > -8.3    正则表达式为:^\d+(?:|\.\d+)$|^-(?:|[0-7])(?:|\.\d+)$|^-8(?:|\.[0-2]\d*)$
 *  >  18     正则表达式为:^18\.\d*[1-9]+\d*$|^[1-9]\d{2,}(?:|\.\d+)$|^[2-9]\d{1}(?:|\.\d+)$|^1[9-9](?:|\.\d+)$
 *  < -13     正则表达式为:^-[1-9]\d{2,}(?:|\.\d+)$|^-[2-9]\d{1}(?:|\.\d+)$|^-1[4-9](?:|\.\d+)$|^-13\.\d*[1-9]+\d*$
 *
 * 整体思路:
 *  针对全体非负数:
 *      小于当前数字所有位数的数字;从高位向低位遍历,遇到0特殊处理;截取前面数字,和小于当前位数字,后面是任意数字,总体长度要和给定数字相等
 *      大于当前数字所有位数的数字;从高位向低位遍历,遇到9特殊处理;截取前面数字,和大于当前位数字,后面是任意数字,总体长度要和给定数字相等
 *      当针对小数时,要多大考虑小数后面的非零数字的特性。
*   当遇到负数时,转换为正数进行计算。
 *
 * @author WeiJinglun
 * @date 2019/10/22
 */
public class RegexTool {
   
    /**
     * 小于指定数字的正则表达式
     */
    public static String transformLessNumber(String s) {
   
        StringBuilder sb = new StringBuilder();
        if (NumberUtil.parseNumber(s).doubleValue() < 0) {
   
            //负数
            s = s.substring(1);
            String[] split = delZero(s.split("\\."));
            if (split.length == 1) {
   
                //整数
                transformGreaterInteger("-", split[0], sb);
                sb.append("|^-").append(split[0]).append("\\.\\d*[1-9]+\\d*$");
            } else if (split.length == 2) {
   
                //小数
                transformGreaterDouble("-", split, sb);
                sb.append("|^-").append(split[0]).append("\\.").append(split[1]).append("\\d*[1-9]+\\d*$");
            }
        } else {
   
            //正数
            String[] split = delZero(s.split("\\."));
            //添加负数
            sb.append("^-\\d+(?:|\\.\\d+)$");
            if (split.length == 1) {
   
                //整数
                transformLessInteger("", split[0], sb);
            } else if (split.length == 2) {
   
                //小数
                transformLessDouble("", split, sb);
            }
        }
        return sb.toString();
    }

    /**
     * 小于等于指定数字的正则表达式
     */
    public static String transformLessOrEqualNumber(String s) {
   
        StringBuilder sb = new StringBuilder();
        if (NumberUtil.parseNumber(s).doubleValue() < 0) {
   
            //负数
            s = s.substring(1);
            String[] split = delZero(s.split("\\."));
            if (split.length == 1) {
   
                //整数
                sb.append("^-").append(split[0]).append("(?:|\\.\\d+)$|");
                transformGreaterInteger("-", split[0], sb);
            } else if (split.length == 2) {
   
                //小数
                sb.append("^-").append(split[0]).append("\\."
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值