• java 正则匹配括号对以及其他成对出现的模式


    最近,我们有个大调整,为了控制代码的质量,需要使用一些伪代码让业务人员编写应用逻辑(其实这么做完全是处于研发效能的考虑,95%以上的代码不需要特别注意都不会导致系统性风险,),然后通过工具自动生成实际的java和SQL代码,其中有个关键点就是处理其中的变量和参数,我们使用了特定的模式进行处理,典型的伪代码类似如下:

    set @机构编号# = @操作员机构编号#;
    [原子_系统状态检查]
    [原子_市场检查]
    [原子_权限检查]
    set @交易日期# = @初始化日期#;
    [原子_交易日期检查]
    [原子_交易时间检查]
    [事务_证券订单重复检查]
    #订单批号小于0,用于老系统的对接. 获取产品资产账户和股东代码
    if @订单批号# < 0 then
      [原子_交易单元获取产品序号资产账户股东代码]
    else
      [原子_账户检查]
      [原子_校验交易单元的操作权限]
    end if;
    
    [原子_交易单元业务权限判断]
    if @指令序号# <> 0 then
      [事务_证券订单交易校验指令业务]
    end if;
    [原子_证券订单代码校验]
    if @订单方向# = 1 then
      [原子_证券订单计算费用]
    end if;
    [原子_证券订单业务校验]
    [原子_交易端证券业务合规判断]
    [检查报错返回][@合规触发类型# = 4][1][concat("订单触发风控合规禁止条件:", @合规触发信息#)]

    我们需要解析出其中的变量和参数,因为我们不打算让工具去控制逻辑语法,所以只要翻译出即可,比如[检查报错返回][@合规触发类型# = 4][1][concat("订单触发风控合规禁止条件:", @合规触发信#)]要解析出”检查报错返回“是宏,后面的是参数,@合规触发类型#是变量。可使用正则表达式如下:

        public static void main(String[] args) {
            System.out.println("解析宏: ");
            parseMacro();
            System.out.println("解析标准字段: ");
            parseField();
        }
    
        /**
         * 
         */
        private static void parseField() {
            String str = "[检查报错返回][@合规触发类型# = 4][1][concat("订单触发风控合规禁止条件:", @合规触发信息#)]";
            String regex = "\@.*?\#";
            Pattern pattern = Pattern.compile(regex);
            Matcher matcher = pattern.matcher(str);
            System.out.println("replace: "+str.replaceAll(regex, "matcher "));
            while (matcher.find()) {
                System.out.println("matcher: " + matcher.group(0));
            }
        }
    
        /**
         * 
         */
        private static void parseMacro() {
            String str = "[检查报错返回][@合规触发类型# = 4][1][concat("订单触发风控合规禁止条件:", @合规触发信息#)]";
            String regex = "\[.*?\]";
            Pattern pattern = Pattern.compile(regex);
            Matcher matcher = pattern.matcher(str);
            System.out.println("replace: "+str.replaceAll(regex, "matcher "));
            while (matcher.find()) {
                System.out.println("matcher: " + matcher.group(0));
            }
        }

    结果如下:

    解析宏: 
    replace: matcher matcher matcher matcher 
    matcher: [检查报错返回]
    matcher: [@合规触发类型# = 4]
    matcher: [1]
    matcher: [concat("订单触发风控合规禁止条件:", @合规触发信息#)]
    解析标准字段: 
    replace: [检查报错返回][matcher  = 4][1][concat("订单触发风控合规禁止条件:", matcher )]
    matcher: @合规触发类型#
    matcher: @合规触发信息#
  • 相关阅读:
    MySQL根据某一个或者多个字段查找重复数据的sql语句
    常见面试题
    技术总监工作内容
    分布式锁三种实现
    完美解决github访问速度慢
    细说Redis
    Mysql学习的核心问题
    Java反射细说
    Spring中的常见的9种设计模式
    Mybatis相关问题
  • 原文地址:https://www.cnblogs.com/zhjh256/p/6256946.html
Copyright © 2020-2023  润新知