Pattern.compile函數(shù)提取字符串中指定的字符(推薦)
最近有個需求是要提取一段字符串中特定范圍內(nèi)的內(nèi)容,查找資料后,使用的是Java中的Pattern.compile函數(shù)來實現(xiàn)對指定字符串的截取。記錄下來查找的知識和應(yīng)用,方便以后的查看。
Pattern.compile函數(shù)語法
// Pattern.compile函數(shù)語法 Pattern Pattern.compile(String regex, int flag)
知識學習
Pattern.compile函數(shù)中兩個參數(shù)
1、regex 表示定義的規(guī)則
2、flag 表示設(shè)置的參數(shù)類型,主要包含以下幾種情況:
(1)Pattern.CASE_INSENSITIVE(?i) 默認情況下,大小寫不明感的匹配只適用于US-ASCII字符集。讓表達式忽略大小寫進行匹配。
(2)Pattern.COMMENTS(?x) 此種模式下,匹配時會忽略表達式中空格字符(表達式里的空格,tab,回車)。注釋從#開始,一直到這行結(jié)束。
(3)Pattern.UNIX_LINES(?d) 此種模式下,只有’\n’才被認作一行的中止,并且與’.’,’^’,以及’$’進行匹配。
(4)Pattern.MULTILINE(?m) 此種模式下,上箭頭和單引號分別匹配一行的開始和結(jié)束。此外,’^‘仍然匹配字符串的開始,’’也匹配字符串的結(jié)束。默認情況下,這兩個表達式僅僅匹配字符串的開始和結(jié)束。
(5)Pattern.DOTALL:此種模式下,表達式’.‘可以匹配任意字符,包括表示一行的結(jié)束符。默認情況下,表達式’.'不匹配行的結(jié)束符。
項目中程序例子
在項目中運用的 flag 的 CASE_INSENSITIVE參數(shù),此處主要是截取中括號中的內(nèi)容,截取的實現(xiàn)代碼如下:
// 引入包
import java.util.regex.Matcher;
import java.util.regex.Pattern;
//需要截取的字符串
String splitStr = "[user:name] = select name from user";
// 定義規(guī)則
String pattern = "(\\[+)(\\w+)\\:(\\w+)(\\]+)";
//Pattern.compile函數(shù)
Matcher matcher = Pattern.compile(pattern, Pattern.CASE_INSENSITIVE).matcher(splitStr);
while (matcher.find()) { //表示往下遍歷
//截取出來的字符串 [user:name]
String allcon = matcher.group(0);
System.out.println("allcon匹配的結(jié)果為"+allcon);
//截取的開始位置 [
String tableJoin1 = matcher.group(1);
System.out.println("tableJoin1匹配的結(jié)果為"+tableJoin1);
//截取出來的表名 user
String tableName = matcher.group(2);
System.out.println("tableName匹配的結(jié)果為"+tableName);
//截取出來的字段名 name
String filed = matcher.group(3);
System.out.println("filed匹配的結(jié)果為"+filed);
//截取的結(jié)束位置 ]
String tableJoin4 = matcher.group(4);
System.out.println("tableJoin4匹配的結(jié)果為"+tableJoin4);
}運行結(jié)果如下圖所示。

本程序中定義的規(guī)則表達式主要提取四個括號內(nèi)的內(nèi)容,以 \\ 符號為開始,后面跟截取的符號,w表示匹配的字符。按照此規(guī)則就可以提取出來相應(yīng)的參數(shù):tableName 表示提取的表名,filed 表示提取的字段名。
參考下面教程:
Pattern.compile函數(shù)的相關(guān)解釋
Pattern.compile函數(shù):Pattern Pattern.compile(String regex, int flag)
flag的取值范圍如下:
Pattern.CANON_EQ:當且僅當兩個字符的"正規(guī)分解(canonical decomposition)"都完全相同的情況下,才認定匹配。比如用了這個標志之后,表達 式"a\u030A"會匹配"?"。默認情況下,不考慮"規(guī)范相等性(canonical equivalence)"。
Pattern.CASE_INSENSITIVE: 默認情況下,大小寫不敏感的匹配只適用于US-ASCII字符集。這個標志能讓表達式忽略大小寫進行匹配。要想對Unicode字符進行大小不明感的匹 配,只要將UNICODE_CASE與這個標志合起來就行了。
Pattern.COMMENTS: 在這種模式下,匹配時會忽略(正則表達式里的)空格字符(不是指表達式里的"\\s",而是指表達式里的空格,tab,回車之類)。注釋從#開始,一直到這行結(jié)束??梢酝ㄟ^嵌入式的標志來啟用Unix行模式。
Pattern.DOTALL: 在這種模式下,表達式'.'可以匹配任意字符,包括表示一行的結(jié)束符。默認情況下,表達式'.'不匹配行的結(jié)束符。
Pattern.MULTILINE: 在這種模式下,'^'和'$'分別匹配一行的開始和結(jié)束。此外,'^'仍然匹配字符串的開始,'$'也匹配字符串的結(jié)束。默認情況下,這兩個表達式僅僅匹配字符串的開始和結(jié)束。
Pattern.UNICODE_CASE: 在這個模式下,如果你還啟用了CASE_INSENSITIVE標志,那么它會對Unicode字符進行大小寫不明感的匹配。默認情況下,大小寫不敏感的匹配只適用于US-ASCII字符集。
Pattern.UNIX_LINES(?d) 在這個模式下,只有'\n'才被認作一行的中止,并且與'.','^',以及'$'進行匹配。
到此這篇關(guān)于Pattern.compile函數(shù)提取字符串中指定的字符的文章就介紹到這了,更多相關(guān)Pattern.compile函數(shù)提取字符串指定字符內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
SpringData @Query和@Modifying注解原理解析
這篇文章主要介紹了SpringData @Query和@Modifying注解原理解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2020-08-08
Java調(diào)用JavaScript實現(xiàn)字符串計算器代碼示例
這篇文章主要介紹了Java調(diào)用JavaScript實現(xiàn)字符串計算器代碼示例,具有一定參考價值,需要的朋友可以了解下。2017-12-12
Spring Boot參數(shù)校驗及分組校驗的使用教程
在日常的開發(fā)中,參數(shù)校驗是非常重要的一個環(huán)節(jié),嚴格參數(shù)校驗會減少很多出bug的概率,增加接口的安全性,下面這篇文章主要給大家介紹了關(guān)于Spring Boot參數(shù)校驗及分組校驗使用的相關(guān)資料,需要的朋友可以參考下2021-08-08

