猿教程 Logo

Java 正则表达式

Java正则表达式是一种用于定义用于搜索或操作字符串的模式的API。

它广泛用于定义对字符串的约束,例如密码和电子邮件验证。 学习java regex教程后,您将能够通过Java Regex测试工具测试您自己的正则表达式。

Java Regex API在java.util.regex包中提供了1个接口和3个类。

java.util.regex package

它为正则表达式提供以下类和接口。 Matcher和Pattern类广泛用于java正则表达式。

  1. MatchResult接口

  2. Matcher类

  3. Pattern类

  4. PatternSyntaxException类


Matcher类

它实现MatchResult接口。 它是一个正则表达式引擎,即用于对字符序列执行匹配操作。

No.方法描述
1boolean matches()测试正则表达式是否匹配模式。
2boolean find()查找与该模式匹配的下一个表达式。
3boolean find(int start)找到与给定开始号码的模式匹配的下一个表达式。
4String group()返回匹配的子序列。
5int start()返回匹配的子序列的起始索引。
6int end()返回匹配的子序列的结束索引。
7int groupCount()返回匹配的子序列的总数。

Pattern类

它是正则表达式的编译版本。 它用于定义正则表达式引擎的模式。

No.方法描述
1static Pattern compile(String regex)编译给定的正则表达式并返回模式的实例。
2Matcher matcher(CharSequence input)创建匹配给定输入与模式的匹配器。
3static boolean matches(String regex,CharSequence input)它作为编译和匹配器方法的组合。 它编译正则表达式,并将给定的输入与模式匹配。
4String[] split(CharSequence input)将给定的输入字符串围绕给定模式的匹配分割。
5String pattern()返回正则表达式模式。

Java正则表达式示例

在java中有三种方式编写正则表达式示例。

相关实例:

import java.util.regex.*;
public class RegexExample1{
public static void main(String args[]){
//1st way
Pattern p = Pattern.compile(".s");//. represents single character
Matcher m = p.matcher("as");
boolean b = m.matches();

//2nd way
boolean b2=Pattern.compile(".s").matcher("as").matches();

//3rd way
boolean b3 = Pattern.matches(".s", "as");

System.out.println(b+" "+b2+" "+b3);
}}

输出

true true true

正则表达式。案例

.(点)表示单个字符。

相关实例:

import java.util.regex.*;
class RegexExample2{
public static void main(String args[]){
System.out.println(Pattern.matches(".s", "as"));//true (2nd char is s)
System.out.println(Pattern.matches(".s", "mk"));//false (2nd char is not s)
System.out.println(Pattern.matches(".s", "mst"));//false (has more than 2 char)
System.out.println(Pattern.matches(".s", "amms"));//false (has more than 2 char)
System.out.println(Pattern.matches("..s", "mas"));//true (3rd char is s)
}}

正则表达式字符类

No.字符类描述
1[abc]a,b或c(简单类)
2[^ abc]除a,b或c以外的任何字符(否定)
3[a-zA-Z]a到z或A到Z,包括(范围)
4[a-d [m-p]]a到d或m到p:[a-dm-p](union)
5[a-z && [def]]d,e或f(交集)
6[a-z && [^ bc]]a到z,除了b和c:[ad-z](减法)
7[a-z && [[m-p]]a到z,而不是m到p:[a-lq-z](减法)

正则表达式字符类示例

相关实例:

import java.util.regex.*;
class RegexExample3{
public static void main(String args[]){
System.out.println(Pattern.matches("[amn]", "abcd"));//false (not a or m or n)
System.out.println(Pattern.matches("[amn]", "a"));//true (among a or m or n)
System.out.println(Pattern.matches("[amn]", "ammmna"));//false (m and a comes more than once)
}}

正则量子

量词指定字符的出现次数。

Regex描述
X?X发生一次或根本不发生
X+X发生一次或多次
X*X发生零次或更多次
X{n}X仅发生n次
X{n,}X发生n次或更多次
X{y,z}X发生至少y次但小于z次

正则表达式字符类和量词例子

相关实例:

import java.util.regex.*;
class RegexExample4{
public static void main(String args[]){
System.out.println("? quantifier ....");
System.out.println(Pattern.matches("[amn]?", "a"));//true (a or m or n comes one time)
System.out.println(Pattern.matches("[amn]?", "aaa"));//false (a comes more than one time)
System.out.println(Pattern.matches("[amn]?", "aammmnn"));//false (a m and n comes more than one time)
System.out.println(Pattern.matches("[amn]?", "aazzta"));//false (a comes more than one time)
System.out.println(Pattern.matches("[amn]?", "am"));//false (a or m or n must come one time)

System.out.println("+ quantifier ....");
System.out.println(Pattern.matches("[amn]+", "a"));//true (a or m or n once or more times)
System.out.println(Pattern.matches("[amn]+", "aaa"));//true (a comes more than one time)
System.out.println(Pattern.matches("[amn]+", "aammmnn"));//true (a or m or n comes more than once)
System.out.println(Pattern.matches("[amn]+", "aazzta"));//false (z and t are not matching pattern)

System.out.println("* quantifier ....");
System.out.println(Pattern.matches("[amn]*", "ammmna"));//true (a or m or n may come zero or more times)

}}

正则表达式元字符

正则表达式元字符用作短代码。

Regex描述
.任何字符(可能匹配或不匹配终结符)
\d任何数字,短缺[0-9]
\D任何非数字,[^ 0-9]
\s任何空格字符,[\ t \ n \ x0B \ f \ r]
\S任何非空格字符,[^ \ s]
\w任何字词,简写为[a-zA-Z_0-9]
\W任何非字字符,[^ \ w]
\b字边界
\B非字边界

正则表达式元字符示例

相关实例:

import java.util.regex.*;
class RegexExample5{
public static void main(String args[]){
System.out.println("metacharacters d....");\\d means digit

System.out.println(Pattern.matches("\\d", "abc"));//false (non-digit)
System.out.println(Pattern.matches("\\d", "1"));//true (digit and comes once)
System.out.println(Pattern.matches("\\d", "4443"));//false (digit but comes more than once)
System.out.println(Pattern.matches("\\d", "323abc"));//false (digit and char)

System.out.println("metacharacters D....");\\D means non-digit

System.out.println(Pattern.matches("\\D", "abc"));//false (non-digit but comes more than once)
System.out.println(Pattern.matches("\\D", "1"));//false (digit)
System.out.println(Pattern.matches("\\D", "4443"));//false (digit)
System.out.println(Pattern.matches("\\D", "323abc"));//false (digit and char)
System.out.println(Pattern.matches("\\D", "m"));//true (non-digit and comes once)

System.out.println("metacharacters D with quantifier....");
System.out.println(Pattern.matches("\\D*", "mak"));//true (non-digit and may come 0 or more times)

}}

正则表达式问题1

相关实例:

/*Create a regular expression that accepts alpha numeric characters only. Its
length must be 6 characters long only.*/

import java.util.regex.*;
class RegexExample6{
public static void main(String args[]){
System.out.println(Pattern.matches("[a-zA-Z0-9]{6}", "arun32"));//true
System.out.println(Pattern.matches("[a-zA-Z0-9]{6}", "kkvarun32"));//false (more than 6 char)
System.out.println(Pattern.matches("[a-zA-Z0-9]{6}", "JA2Uk2"));//true
System.out.println(Pattern.matches("[a-zA-Z0-9]{6}", "arun$2"));//false ($ is not matched)
}}

问题2

相关实例:

/*Create a regular expression that accepts 10 digit numeric characters
 starting with 7, 8 or 9 only.*/

import java.util.regex.*;
class RegexExample7{
public static void main(String args[]){
System.out.println("by character classes and quantifiers ...");
System.out.println(Pattern.matches("[789]{1}[0-9]{9}", "9953038949"));//true
System.out.println(Pattern.matches("[789][0-9]{9}", "9953038949"));//true

System.out.println(Pattern.matches("[789][0-9]{9}", "99530389490"));//false (11 characters)
System.out.println(Pattern.matches("[789][0-9]{9}", "6953038949"));//false (starts from 6)
System.out.println(Pattern.matches("[789][0-9]{9}", "8853038949"));//true

System.out.println("by metacharacters ...");
System.out.println(Pattern.matches("[789]{1}\\d{9}", "8853038949"));//true
System.out.println(Pattern.matches("[789]{1}\\d{9}", "3853038949"));//false (starts from 3)

}}

Java Regex Finder示例

相关实例:

import java.util.regex.Pattern;
import java.util.Scanner;
import java.util.regex.Matcher;  
public class RegexExample8{  
    public static void main(String[] args){  
        Scanner sc=new Scanner(System.in);
        while (true) {  
        	System.out.println("Enter regex pattern:");
            Pattern pattern = Pattern.compile(sc.nextLine());  
            System.out.println("Enter text:");
            Matcher matcher = pattern.matcher(sc.nextLine());  
            boolean found = false;  
            while (matcher.find()) {  
                System.out.println("I found the text "+matcher.group()+" starting at index "+  
                 matcher.start()+" and ending at index "+matcher.end());  
                found = true;  
            }  
            if(!found){  
                System.out.println("No match found.");  
            }  
        }  
    }  
}

输出:

Enter regex pattern: java
Enter text: this is java, do you know java
I found the text java starting at index 8 and ending at index 12
I found the text java starting at index 26 and ending at index 30


版权声明:本站所有教程均为本站原创或翻译,转载请注明出处,请尊重他人劳动果实。请记住本站地址:www.yuanjiaocheng.net (猿教程) 作者:卿文刚
本文标题: C#环境
本文地址:http://www.yuanjiaocheng.net/Java/java-regex.html