判斷目標(biāo)字符串中是否 可能 含這個(gè)字符。
假如待匹配字符串包含指定字符串并且匹配正則表達(dá)式,則為真,假如待匹配字符串不包含指定字符串但是匹配正則表達(dá)式,也為真,假如其他情況為假。
看一段簡(jiǎn)單的代碼示例:
private static String s = "1";
public static void main(String[] args) {
testOne(s);
}
private static void testOne(String s){
System.out.println(s.matches("1?"));
}
這段程序測(cè)試的是s中是否包含"1",假如包含則返回true,不包含則返回false。此處運(yùn)行程序結(jié)果得到: true 。
注意此處?的用法不同于contains的用法,contains用于測(cè)試字符串中是否包含某個(gè)字符串,match后的參數(shù)則是整個(gè)字符串的正則形式。
可以再做一個(gè)簡(jiǎn)單的測(cè)試:
private static String s = "1java";
public static void main(String[] args) {
testOne(s);
}
private static void testOne(String s){
System.out.println(s.matches("1?"));
}
此處將待匹配的字符串改成了"1java",運(yùn)行此程序顯示的結(jié)果為 false 。此時(shí)我們?cè)俅紊晕⑿薷囊幌录纯桑?/p>
private static String s = "1java";
public static void main(String[] args) {
testOne(s);
}
private static void testOne(String s){
System.out.println(s.matches("1?[a-z]+"));
}
上面的代碼修改了了一下match中的參數(shù),此時(shí)結(jié)果即為 true 。
再來(lái)看一個(gè)情況
private static String s = "12";
public static void main(String[] args) {
testOne(s);
}
private static void testOne(String s){
System.out.println(s.matches("0?\\d+"));
}
此時(shí)返回的結(jié)果仍為 true ,待匹配字符串中不包含"0",但是后邊的表達(dá)式"\d+"完全匹配"12"。所以返回true。
2. "\"的作用
轉(zhuǎn)義符
在java中的String使用中,我們知道"\"表示轉(zhuǎn)義符。當(dāng)我們需要表示
String s="He is a "Monster"";
其中的 " " 不能直接寫(xiě)入字符串中,否則編譯器會(huì)直接報(bào)錯(cuò)。需要經(jīng)過(guò)轉(zhuǎn)義符來(lái)轉(zhuǎn)換:
String s="He is a \"Monster\"";
但是在java中的正則表達(dá)式中,有時(shí)候需要用到"\"來(lái)表示一些特定的符號(hào),比如 \d 在正則表達(dá)式中表示匹配一位數(shù)字,但用到正則表達(dá)式中則必須使用 \\ 這樣的雙反斜杠來(lái)表示一個(gè) \ 。也就是說(shuō)我們?cè)诖a中必須寫(xiě)成 \\d 來(lái)匹配一個(gè)數(shù)組,相當(dāng)于正則表達(dá)式中的 \d 。
假如你想在正則表達(dá)式中插入一個(gè)正常的 \ ,則需要寫(xiě)入 \\\\ 。
private static String s = "\\12";
public static void main(String[] args) {
testOne(s);
}
private static void testOne(String s){
System.out.println(s);
System.out.println(s.contains("\\"));
System.out.println(s.matches("\\\\?\\d+"));
}
注意看一下這段程序中的表示: s=\12 ,這是我們的待匹配字符串,它包含了一個(gè) \ 和兩個(gè)數(shù)字 12 。 String.contains()方法能匹配字符串,可以使用正常的 \\ 表示方法,但是在String.match()方法中是正則表達(dá)式,此時(shí)必須使用 \\\\ 來(lái)表示一個(gè)正常的 \ 方可匹配成功。
3. "+"的作用
一個(gè)或多個(gè)之前的表達(dá)式
前邊已經(jīng)稍微解釋過(guò)這個(gè)字符的作用, \\d 表示匹配一個(gè)數(shù)字,在后邊加上一個(gè)"+"則表示匹配一個(gè)或多個(gè)數(shù)字
private static String s = "12345";
public static void main(String[] args) {
testOne(s);
}
private static void testOne(String s){
System.out.println(s.matches("\\\\?\\d+"));
}
無(wú)論s中包含多少個(gè)數(shù)字,只要全部是數(shù)字即可匹配。假如要匹配 123 則需要用如下表達(dá)式:
(123)+
有一種錯(cuò)誤寫(xiě)法如下:
123+
這種表示首先匹配12,然后匹配多個(gè)3。 代碼測(cè)試:
private static String s = "1233";
public static void main(String[] args) {
testOne(s);
}
private static void testOne(String s){
System.out.println(s.matches("123+"));
}
輸出為真,此時(shí)就是匹配的12+多個(gè)3。
量詞
量詞表示一個(gè)正則表達(dá)式在匹配的過(guò)程中的模式
- 貪婪型 一般的匹配模式總是貪婪型的,除非被設(shè)置了其他選項(xiàng)。貪婪表達(dá)式會(huì)為所有可能的匹配來(lái)盡可能的匹配,也就是匹配最多的字符串。
- 勉強(qiáng)型 用問(wèn)號(hào)來(lái)制定,勉強(qiáng)表達(dá)式會(huì)盡可能少的匹配,也就是匹配最少的字符串。
- 占有型 這種類(lèi)型是java中特有的
貪婪型 |
勉強(qiáng)型 |
占有型 |
說(shuō)明 |
X? |
X?? |
X?+ |
一個(gè)或0個(gè)X |
X* |
X*? |
X*+ |
0個(gè)或多個(gè)X |
X+ |
X+? |
X++ |
一個(gè)或多個(gè)X |
X{n} |
X{n}? |
X{n}+ |
恰好n次X |
X{n,} |
X{n,}? |
X{n,}+ |
至少n次X |
X{n,m} |
X{n,m}? |
X{n,m}+ |
至少n次,至多m次X |
正則表達(dá)式中的字符
字符
下表展示了一些常用的字符表示
示例 |
說(shuō)明 |
B |
指定字符B |
\xhh |
16進(jìn)制表示字符,0xhh |
\uhhhh |
16進(jìn)制表示unicode字符0xhhhh |
\t |
制表符TAB |
\n |
換行符 |
\r |
回車(chē) |
\f |
換頁(yè) |
\e |
轉(zhuǎn)義(escape) |
字符類(lèi)
下表列出了正則表達(dá)式中常用的字符類(lèi)
示例 |
說(shuō)明 |
. |
匹配任意單個(gè)字符 |
[abc] |
包含abc中任意的字符,等價(jià)于a |
[^abc] |
除了abc外的任意字符 |
[a-zA-Z] |
從a到z或者從A到Z中的任意字符 |
[abd[1-9]] |
abd中任意字符或者1-9中任意字符,取并集 |
[a-z[hij]] |
任意h、i、j字符,取交集 |
\s |
空白符(空格、tab、換行、換頁(yè)和回車(chē)) |
\S |
非空白符(^\s) |
\d |
數(shù)字(0-9) |
\D |
非數(shù)字(^0-9) |
\w |
詞字符[a-zA-Z0-9] |
\W |
非詞字符[^\w] |
邏輯操作符
示例 |
說(shuō)明 |
XY |
Y跟在X后邊 |
X |
Y |
(X) |
捕獲組 |
邊界匹配符
例 |
說(shuō)明 |
^ |
一行的起始 |
$ |
一行的結(jié)束 |
\b |
詞的邊界 |
\B |
非詞的邊界 |
\G |
前一個(gè)匹配的結(jié)束 |
一個(gè)簡(jiǎn)單的例子來(lái)創(chuàng)建上面表中的正則表達(dá)式
private static String s = "java123\nJAVA";//形式為"[a-z]{4}[0-9]{3}\s[A-Z]{4}
public static void main(String[] args) {
testOne(s);
}
private static void testOne(String s) {
System.out.println(s);
System.out.println(s.matches(".+\\s.\\S+"));//測(cè)試"."匹配任意字符與空白字符"\s與非空白字符\S"
System.out.println(s.matches("[a-z]+[1-9]+\\s[A-Z]+"));//測(cè)試[a-zA-Z0-9]的任意匹配
System.out.println(s.matches("[^0-9]+[^a-z]+[^\\S][^a-z]+"));//測(cè)試^(非)
System.out.println(s.matches("[bv[ja]]+[123]+\\s[A-Z1JAV]+"));//測(cè)試與和或
System.out.println(s.matches("\\w{4}\\d{3}\\s\\w{4}"));//測(cè)試\w詞字符與\d數(shù)字
System.out.println(s.matches("\\D{4}\\w{3}\\W\\D{4}"));//測(cè)試非詞字符\W與非數(shù)字\D
}
注釋中已經(jīng)寫(xiě)的相當(dāng)清楚了,輸出結(jié)果為:
java123
JAVA
true
true
true
true
true
true
總結(jié)
以上所述是小編給大家介紹的java中的正則表達(dá)式,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
您可能感興趣的文章:- Java使用正則表達(dá)式驗(yàn)證手機(jī)號(hào)和電話號(hào)碼的方法
- java 正則表達(dá)式獲取兩個(gè)字符中間的字符串方法
- java基于正則表達(dá)式實(shí)現(xiàn)時(shí)間日期的常用判斷操作實(shí)例
- JAVA環(huán)境搭建之MyEclipse10+jdk1.8+tomcat8環(huán)境搭建詳解
- java 偽造http請(qǐng)求ip地址的方法
- tomcat啟動(dòng)報(bào)錯(cuò):java.util.zip.ZipException的解決方法
- java正則表達(dá)式判斷 ip 地址是否正確解析