logo

Java Regex

De Java Regex eller Regular Expression är ett API till definiera ett mönster för att söka eller manipulera strängar .

Det används ofta för att definiera restriktioner för strängar som lösenord och e-postvalidering. Efter att ha lärt dig Java Regex-handledning kommer du att kunna testa dina reguljära uttryck med Java Regex Tester Tool.

Java Regex API ger 1 gränssnitt och 3 klasser i java.util.regex paket.

java.util.regex-paketet

Matcher- och Pattern-klasserna ger möjligheten till Java reguljära uttryck. Paketet java.util.regex tillhandahåller följande klasser och gränssnitt för reguljära uttryck.

  1. MatchResult-gränssnitt
  2. Matcherklass
  3. Mönsterklass
  4. Klassen PatternSyntaxException
Java Regex API

Matcherklass

Den implementerar MatchResult gränssnitt. Det är en regex motor som används för att utföra matchningsoperationer på en teckensekvens.

Nej.MetodBeskrivning
1booleska matcher()testa om det reguljära uttrycket matchar mönstret.
2booleskt fynd()hittar nästa uttryck som matchar mönstret.
3booleskt fynd (int start)hittar nästa uttryck som matchar mönstret från det givna startnumret.
4Stränggrupp()returnerar den matchade undersekvensen.
5int start()returnerar startindexet för den matchade undersekvensen.
6int end()returnerar slutindexet för den matchade undersekvensen.
7int groupCount()returnerar det totala antalet av den matchade undersekvensen.

Mönsterklass

Det är kompilerad version av ett reguljärt uttryck . Den används för att definiera ett mönster för regexmotorn.

Nej.MetodBeskrivning
1statisk mönsterkompilering (Regex String)kompilerar det givna regexet och returnerar instansen av mönstret.
2Matchningsmatchning(CharSequence-ingång)skapar en matchare som matchar den givna inmatningen med mönstret.
3statiska booleska matchningar (String regex, CharSequence input)Det fungerar som en kombination av kompilering och matchningsmetoder. Det kompilerar det reguljära uttrycket och matchar den givna inmatningen med mönstret.
4String[] split(CharSequence-ingång)delar den givna inmatningssträngen runt matchningar av givet mönster.
5Strängmönster()returnerar regexmönstret.

Exempel på reguljära Java-uttryck

Det finns tre sätt att skriva regex-exemplet i 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); }} 
Testa det nu

Produktion

 true true true 

Vanligt uttryck . Exempel

Den . (punkt) representerar ett enda tecken.

 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) }} 
Testa det nu

Regex karaktärsklasser

Nej.KaraktärsklassBeskrivning
1[abc]a, b eller c (enkel klass)
2[^abc]Vilket tecken som helst utom a, b eller c (negation)
3[a-zA-Z]a till z eller A till och med Z, inklusive (intervall)
4[a-d[m-p]]a till d, eller m till och med p: [a-dm-p] (union)
5[a-z&&[def]]d, e eller f (korsning)
6[a-z&&[^bc]]a till z, förutom b och c: [ad-z] (subtraktion)
7[a-z&&[^m-p]]a till z, och inte m till p: [a-lq-z](subtraktion)

Reguljära uttryck Teckenklasser Exempel

 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) }} 
Testa det nu

Regex kvantifierare

Kvantifierarna anger antalet förekomster av ett tecken.

RegexBeskrivning
X?X förekommer en gång eller inte alls
X+X förekommer en eller flera gånger
X*X förekommer noll eller fler gånger
X{n}X förekommer endast n gånger
X{n,}X förekommer n eller flera gånger
X{y,z}X förekommer minst y gånger men mindre än z gånger

Reguljära uttryck Teckenklasser och kvantifierare Exempel

 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) }} 
Testa det nu

Regex Metatecken

De reguljära uttryckets metatecken fungerar som kortkoder.

RegexBeskrivning
.Vilket tecken som helst (kan eller kanske inte matchar terminator)
dAlla siffror, kortare än [0-9]
DAlla icke-siffriga, kort för [^0-9]
sVilket blanksteg som helst, förkortning för [ x0Bf ]
SAlla tecken som inte är blanksteg, kort för [^s]
IVilket ord som helst, förkortning för [a-zA-Z_0-9]
IAlla tecken som inte består av ord, förkortning för [^w]
En ordgräns
BEn icke ordgräns

Reguljära uttrycksmetakaraktärer Exempel

 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) }} 
Testa det nu

Reguljära uttrycksfråga 1

 /*Create a regular expression that accepts alphanumeric characters only. Its length must be six 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) }} 

Testa det nu

Reguljära uttrycksfråga 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) }} 
Testa det nu

Exempel på 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.'); } } } } 

Produktion:

 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