• java 字符串中参数化符号${}的解析


    我们在很多地方都能看到代表参数意义的符号${},可能我们在写一些框架的时候,有时候也需要用到这个符号,但他们是如何精确解析的?或者说需要我们自已写的时候,如何写?我们先来看以下的几个场景:

    1.字符串"a${a}a"

    2.字符串"a${a}a"

    3.字符串"a${a}a"

    4.字符串"a${a}a}a"

    5.字符串"a${a}a${"

    6.字符串"a${a}a${a}"

    以上几个字符串中,基本上包括了使用的一些场景,所以我们在解析的时候,要把各种情况都考虑清楚,尽量的做到全面,这样我们的框架才有意义。

    很显然,我们都会采用正则来解析,于是我们来新建一个JAVA正则的类:

    public class RegExp {
    
    	public boolean match(String reg, String str) {
    		return Pattern.matches(reg, str);
    	}
    
    	public List<String> find(String reg, String str) {
    		Matcher matcher = Pattern.compile(reg).matcher(str);
    		List<String> list = new ArrayList<String>();
    		while (matcher.find()) {
    			list.add(matcher.group());
    		}
    		return list;
    	}
    	
    	public List<String> find(String reg, String str, int index) {
    		Matcher matcher = Pattern.compile(reg).matcher(str);
    		List<String> list = new ArrayList<String>();
    		while (matcher.find()) {
    			list.add(matcher.group(index));
    		}
    		return list;
    	}
    	
    	public String findString(String reg, String str, int index) {
    		String returnStr = null;
    		List<String> list = this.find(reg, str, index);
    		if (list.size() != 0)
    			returnStr = list.get(0);
    		return returnStr;		
    	}
    
    	public String findString(String reg, String str) {
    		String returnStr = null;
    		List<String> list = this.find(reg, str);
    		if (list.size() != 0)
    			returnStr = list.get(0);
    		return returnStr;
    	}
    
    	
    
    	public static void main(String[] args) {
    		RegExp re = new RegExp();
    		System.out.println(re.find("(a)b", "ababab", 1));
    	}
    }
    

     然后开始来解析了,很简单,一个正则即可:

    public class ParseKeyword {
    	
    	public List<String> getKeywords(String p){
    	    String reg = "(?<=(?<!\\)\$\{)(.*?)(?=(?<!\\)\})";     
    	    RegExp re = new RegExp();
    	    List<String> list = re.find(reg, p);
    	    return list;
    	}
    	
    	public static void main(String[] args) {
    		ParseKeyword p = new ParseKeyword();
    		System.out.println(p.getKeywords("a${a}a"));
    		System.out.println(p.getKeywords("a\${a}a"));
    		System.out.println(p.getKeywords("a${a\}a"));
    		System.out.println(p.getKeywords("a${a\}a}a"));
    		System.out.println(p.getKeywords("a${a}a${"));
    		System.out.println(p.getKeywords("a${ab}a${a}"));
    	}
    }
    

     总结一下:解析这个参数符号,要掌握的主要是正则,其中尤其以预查模式(欢迎访问我的一篇关于预查模式的博客),然后其它的就是一些字符串的操作方法了。

    希望能对大家有用。

  • 相关阅读:
    CVE-2021-25646 Apache Druid远程命令执行漏洞复现
    CVE-2021-3156漏洞复现
    助力抗疫 Splashtop 远程控制软件限时免费
    Splashtop Business Access 的常见问题解答
    热烈祝贺 Splashtop 荣获“最佳远程办公解决方案”奖
    Mark Lee:Splashtop 如何成为最新的 10 亿美元估值技术独角兽
    Splashtop获5000万美元新投资 成为远程桌面行业独角兽
    热烈祝贺 Splashtop 赢得最佳远程桌面用户满意度得分
    [翻译系列]正则表达式简介
    tensorflow2.0 keras 迁移学习 删除预训练模型的最后一层(layer)
  • 原文地址:https://www.cnblogs.com/zhangfei/p/4797622.html
Copyright © 2020-2023  润新知