正則表達(dá)式匹配${key}并在Java中使用的詳細(xì)方法
${([a-z]+)} 能夠匹配字符串中以${key}形式的文本(其中key為小寫英文字母)
.*${([a-z]+)}.* 可以用來檢測文本中是否有${key}形式的文本
解釋如下:
. 匹配除換行符n之外的任何單字符
* 匹配前面的子表達(dá)式零次或多次 要匹配*字符,請使用*
{ 標(biāo)記限定符表達(dá)式的開始。要匹配 {,請使用 {
[a-z] 匹配小寫字母
+匹配前面的子表達(dá)式一次或多次。要匹配+字符,請使用+;+限定是貪婪的,因?yàn)樗鼈儠M可能多的匹配文字,只有在它們的后面加上一個?就可以實(shí)現(xiàn)非貪婪或最小匹配。
()標(biāo)記一個子表達(dá)式的開始和結(jié)束位置。子表達(dá)式可以獲取供以后使用。要匹配這些字符,請使用 (和 )
下圖展示了括號的選擇作用
這里直接貼代碼了
package test;import com.sun.xml.internal.ws.api.model.wsdl.WSDLOutput;import java.util.ArrayList;import java.util.LinkedHashSet;import java.util.List;import java.util.Set;import java.util.regex.Matcher;import java.util.regex.Pattern;/** * @Author Song * @Date 2021/2/26 16:55 * @Version 1.0 * @Description */public class TestUtil { /** * 利用好其預(yù)編譯功能,可以有效加快正則匹配速度 */ public static Pattern dynamic = Pattern.compile('.*${([a-z]+)}.*'); public static Pattern dynamicLimitCount = Pattern.compile('${([a-z]+)}'); /** * 判斷內(nèi)容中是否包含動態(tài)參數(shù)(${key}形式的) * * @param content 要判斷的內(nèi)容 * @return */ public static boolean isContainsDynamicParameter(String content) { return dynamic.matcher(content).matches(); } /** * 按照動態(tài)內(nèi)容的參數(shù)出現(xiàn)順序,將參數(shù)放到List中 * * @param content * @return */ public static List<String> getKeyListByContent(String content) { Set<String> paramSet = new LinkedHashSet<>(); Matcher m = dynamicLimitCount.matcher(content); while (m.find()) { paramSet.add(m.group(1)); } return new ArrayList<>(paramSet); } public static void main(String[] args) { //測試代碼 String content = '尊敬的${name}客戶您好,請于${time}前到達(dá)'; System.out.println(isContainsDynamicParameter(content)); List<String> keyListByContent = getKeyListByContent(content); System.out.println('內(nèi)容中的動態(tài)參數(shù)為:'); keyListByContent.forEach(System.out::println); }}
測試代碼的運(yùn)行結(jié)果如圖
參考
菜鳥教程-正則表達(dá)式
到此這篇關(guān)于正則表達(dá)式匹配${key}并在Java中使用的詳細(xì)方法的文章就介紹到這了,更多相關(guān)正則表達(dá)式匹配${key}內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. 利用CSS3新特性創(chuàng)建透明邊框三角2. html清除浮動的6種方法示例3. CSS代碼檢查工具stylelint的使用方法詳解4. Vue3使用JSX的方法實(shí)例(筆記自用)5. vue實(shí)現(xiàn)將自己網(wǎng)站(h5鏈接)分享到微信中形成小卡片的超詳細(xì)教程6. CSS3實(shí)例分享之多重背景的實(shí)現(xiàn)(Multiple backgrounds)7. 詳解CSS偽元素的妙用單標(biāo)簽之美8. 使用css實(shí)現(xiàn)全兼容tooltip提示框9. JavaScript數(shù)據(jù)類型對函數(shù)式編程的影響示例解析10. 不要在HTML中濫用div
