Java Regex - Hızlı Kılavuz

Java, normal ifadelerle kalıp eşleşmesi için java.util.regex paketini sağlar. Java normal ifadeleri Perl programlama diline çok benzer ve öğrenmesi çok kolaydır.

Normal ifade, bir modelde tutulan özel bir sözdizimini kullanarak diğer dizeleri veya dize kümelerini eşleştirmenize veya bulmanıza yardımcı olan özel bir karakter dizisidir. Metin ve verileri aramak, düzenlemek veya değiştirmek için kullanılabilirler.

Java.util.regex paketi öncelikle aşağıdaki üç sınıftan oluşur -

  • Pattern Class- Bir Desen nesnesi, bir normal ifadenin derlenmiş bir temsilidir. Pattern sınıfı hiçbir genel yapıcı sağlamaz. Bir model oluşturmak için önce genel statiklerinden birini çağırmalısınız.compile()yöntemler, daha sonra bir Pattern nesnesi döndürür. Bu yöntemler, ilk argüman olarak bir normal ifadeyi kabul eder.

  • Matcher Class- Bir Matcher nesnesi, modeli yorumlayan ve bir giriş dizesine karşı eşleştirme işlemleri gerçekleştiren motordur. Pattern sınıfı gibi, Matcher hiçbir genel kurucu tanımlamaz. Bir Matcher nesnesi elde edersiniz.matcher() Bir Pattern nesnesinde yöntem.

  • PatternSyntaxException - Bir PatternSyntaxException nesnesi, normal ifade modelinde bir sözdizimi hatasını gösteren denetlenmemiş bir istisnadır.

Grupları yakalama, birden çok karakteri tek bir birim olarak ele almanın bir yoludur. Gruplanacak karakterlerin bir parantez seti içine yerleştirilmesiyle oluşturulurlar. Örneğin, normal ifade (köpek) "d", "o" ve "g" harflerini içeren tek bir grup oluşturur.

Yakalama grupları, soldan sağa açılış parantezleri sayılarak numaralandırılır. Örneğin ((A) (B (C))) ifadesinde, bu tür dört grup vardır -

  • ((A)(B(C)))
  • (A)
  • (B(C))
  • (C)

İfadede kaç grup olduğunu öğrenmek için, bir eşleştirme nesnesinde groupCount yöntemini çağırın. GroupCount yöntemi birint eşleştiricinin deseninde bulunan yakalama gruplarının sayısını gösterir.

Ayrıca her zaman tüm ifadeyi temsil eden özel bir grup 0 vardır. Bu grup, groupCount tarafından bildirilen toplama dahil değildir.

Misal

Aşağıdaki örnek, verilen alfanümerik dizeden bir rakam dizesinin nasıl bulunacağını gösterir -

import java.util.regex.Matcher;
import java.util.regex.Pattern;

public class RegexMatches {
   public static void main( String args[] ) {
      // String to be scanned to find the pattern.
      String line = "This order was placed for QT3000! OK?";
      String pattern = "(.*)(\\d+)(.*)";

      // Create a Pattern object
      Pattern r = Pattern.compile(pattern);

      // Now create matcher object.
      Matcher m = r.matcher(line);
      
      if (m.find( )) {
         System.out.println("Found value: " + m.group(0) );
         System.out.println("Found value: " + m.group(1) );
         System.out.println("Found value: " + m.group(2) );
      } else {
         System.out.println("NO MATCH");
      }
   }
}

Bu, aşağıdaki sonucu verecektir -

Çıktı

Found value: This order was placed for QT3000! OK?
Found value: This order was placed for QT300
Found value: 0

Giriş

java.util.regex.MatchResultarayüz bir eşleşme işleminin sonucunu temsil eder. Bu arabirim, bir normal ifadeyle eşleşmenin sonuçlarını belirlemek için kullanılan sorgu yöntemlerini içerir. Maç sınırları, gruplar ve grup sınırları bir MatchResult aracılığıyla görülebilir ancak değiştirilemez.

Arayüz bildirimi

Aşağıdaki beyanı java.util.regex.MatchResult arayüz -

public interface MatchResult

Arayüz yöntemleri

Sr.No Yöntem ve Açıklama
1 niyet etmek()

Eşleşen son karakterden sonraki uzaklığı döndürür.

2 int end (int grup)

Bu maç sırasında verilen grup tarafından yakalanan alt dizinin son karakterinden sonraki ofseti döndürür.

3 Dize grubu ()

Önceki eşleşmeyle eşleşen giriş alt dizisini döndürür.

4 Dize grubu (int grubu)

Önceki eşleme işlemi sırasında verilen grup tarafından yakalanan girdi alt dizisini döndürür.

5 int groupCount ()

Bu eşleşme sonucu modelindeki yakalama gruplarının sayısını döndürür.

6 int başlangıç ​​()

Eşleşmenin başlangıç ​​dizinini döndürür.

7 int başlangıç ​​(int grup)

Bu eşleşme sırasında verilen grup tarafından yakalanan alt dizinin başlangıç ​​dizinini döndürür.

Giriş

java.util.regex.Pattern class, bir düzenli ifadenin derlenmiş bir temsilini temsil eder.

Sınıf beyanı

Aşağıdaki beyanı java.util.regex.Pattern sınıf -

public final class Pattern
   extends Object
      implements Serializable

Alan

Aşağıdakiler için alanlar java.util.regex.Duration sınıf -

  • static int CANON_EQ - Kanonik denkliği etkinleştirir.

  • static int CASE_INSENSITIVE - Büyük / küçük harfe duyarlı olmayan eşleştirmeyi etkinleştirir.

  • static int COMMENTS - Kalıpta boşluklara ve yorumlara izin verir.

  • static int DOTALL - Dotall modunu etkinleştirir.

  • static int LITERAL - Desenin değişmez ayrıştırılmasını sağlar.

  • static int MULTILINE - Çok satırlı modu etkinleştirir.

  • static int UNICODE_CASE - Unicode duyarlı kasa katlamayı etkinleştirir.

  • static int UNICODE_CHARACTER_CLASS - Önceden tanımlanmış karakter sınıflarının ve POSIX karakter sınıflarının Unicode sürümünü etkinleştirir.

  • static int UNIX_LINES - Unix hatları modunu etkinleştirir.

Sınıf yöntemleri

Sr.No Yöntem ve Açıklama
1 statik Desen derlemesi (String regex)

Verilen normal ifadeyi bir modelde derler.

2 statik Desen derlemesi (Dize normal ifadesi, int bayrakları)

Verilen normal ifadeyi verilen bayraklarla bir modelde derler.

3 int bayraklar ()

Bu kalıbın eşleşme bayraklarını döndürür.

4 Eşleştirici eşleştirici (CharSequence girişi)

Verilen girdiyle bu şablonla eşleşecek bir eşleştirici oluşturur.

5 statik boole eşleşmeleri (String regex, CharSequence girişi)

Verilen normal ifadeyi derler ve verilen girdiyi onunla eşleştirmeye çalışır.

6 IP dizgesi()

Bu desenin derlendiği normal ifadeyi döndürür.

7 statik String alıntı (String ler)

Belirtilen String için değişmez bir model String döndürür.

8 Dize [] bölme (CharSequence girişi)

Verilen giriş sırasını bu modelin eşleşmeleri etrafında böler.

9 String [] bölme (CharSequence girişi, int sınırı)

Verilen giriş sırasını bu modelin eşleşmeleri etrafında böler.

10 String toString ()

Bu desenin dize gösterimini döndürür.

Miras alınan yöntemler

Bu sınıf, yöntemleri aşağıdaki sınıflardan miras alır -

  • Java.lang.Object

Giriş

java.util.regex.Matcher sınıfı, bir Modeli yorumlayarak bir karakter dizisi üzerinde eşleştirme işlemleri gerçekleştiren bir motor görevi görür.

Sınıf beyanı

Aşağıdaki beyanı java.util.regex.Matcher sınıf -

public final class Matcher
   extends Object
      implements MatchResult

Sınıf yöntemleri

Sr.No Yöntem ve Açıklama
1 Matcher appendReplacement (StringBuffer sb, String değişimi)

Terminal olmayan bir ekleme ve değiştirme adımı uygular.

2 StringBuffer appendTail (StringBuffer sb)

Bir uçbirim ekleme ve değiştirme adımını uygular.

3 niyet etmek()

Eşleşen son karakterden sonraki uzaklığı döndürür.

4 int end (int grup)

Önceki maç işlemi sırasında verilen grup tarafından yakalanan alt dizinin son karakterinden sonraki ofseti döndürür.

5 boole bul ()

Desenle eşleşen giriş dizisinin bir sonraki alt dizisini bulmaya çalışır.

6 boolean bulma (int başlangıç)

Bu eşleştiriciyi sıfırlar ve ardından, belirtilen dizinden başlayarak modelle eşleşen giriş dizisinin bir sonraki alt dizisini bulmaya çalışır.

7 Dize grubu ()

Önceki eşleme işlemi sırasında verilen grup tarafından yakalanan girdi alt dizisini döndürür.

8 Dize grubu (Dize adı)

Önceki eşleme işlemi sırasında verilen adlandırılmış yakalama grubu tarafından yakalanan girdi alt dizisini döndürür.

9 int groupCount ()

Bu eşleştiricinin modelindeki yakalama gruplarının sayısını verir.

10 boolean hasAnchoringBounds ()

Bu eşleştirici için bölge sınırlarının sabitlenmesini sorgular.

11 boolean hasTransparentBounds ()

Bu eşleştirici için bölge sınırlarının şeffaflığını sorgular.

12 boolean hitEnd ()

Bu eşleştirici tarafından gerçekleştirilen son eşleştirme işleminde girişin sonu arama motoru tarafından vurulursa doğru döndürür.

13 boolean görünümlüAt ()

Girdi sırasını, bölgenin başlangıcından başlayarak modelle eşleştirmeye çalışır.

14 boole eşleşmeleri ()

Kalıpla tüm bölgeyi eşleştirmeye çalışır.

15 Desen deseni ()

Bu eşleştirici tarafından yorumlanan modeli döndürür.

16 statik String quoteReplacement (String ler)

Belirtilen String için değişmez bir değiştirme String döndürür.

17 Eşleştirici bölge (int start, int end)

Bu eşleştiricinin bölgesinin sınırlarını ayarlar.

18 int regionEnd ()

Bu eşleştiricinin bölgesinin bitiş endeksini (hariç) bildirir.

19 int regionStart ()

Bu eşleştiricinin bölgesinin başlangıç ​​endeksini bildirir.

20 String replaceAll (Dize değişimi)

Girdi dizisinin, modelle eşleşen her alt dizisini verilen değiştirme dizesiyle değiştirir.

21 String replaceFirst (Dize değişimi)

Desenle eşleşen giriş dizisinin ilk alt dizisini verilen değiştirme dizesiyle değiştirir.

22 boolean requireEnd ()

Daha fazla girdi, pozitif bir eşleşmeyi negatif bir eşleşmeye dönüştürebiliyorsa doğru döndürür.

23 Eşleştirici sıfırlama ()

Bu eşleştiriciyi sıfırlar.

24 Eşleştirici sıfırlama (CharSequence girişi)

Bu eşleştiriciyi yeni bir giriş sırası ile sıfırlar.

25 int başlangıç ​​()

Önceki eşleşmenin başlangıç ​​dizinini döndürür.

26 int başlangıç ​​(int grup)

Önceki eşleme işlemi sırasında belirli grup tarafından yakalanan alt dizinin başlangıç ​​dizinini döndürür.

27 MatchResult toMatchResult ()

Bu eşleştiricinin eşleşme durumunu MatchResult olarak döndürür.

28 String toString ()

Bu eşleştiricinin dize gösterimini döndürür.

29 Eşleştirici kullanımıAnchoringBounds (boolean b)

Bu eşleştirici için bölge sınırlarının ankrajını ayarlar.

30 Matcher usePattern (Pattern newPattern)

Bu Eşleştiricinin eşleşmeleri bulmak için kullandığı Modeli değiştirir.

31 Eşleştirici kullanımıTransparentBounds (boolean b)

Bu eşleştirici için bölge sınırlarının şeffaflığını ayarlar.

Miras alınan yöntemler

Bu sınıf, yöntemleri aşağıdaki sınıflardan miras alır -

  • Java.lang.Object

Giriş

java.util.regex.PatternSyntaxException sınıfı, normal ifade modelinde bir sözdizimi hatasını belirtmek için atılan denetlenmemiş bir istisnayı temsil eder.

Sınıf beyanı

Aşağıdaki beyanı java.util.regex.PatternSyntaxException sınıf -

public class PatternSyntaxException
   extends IllegalArgumentException

İnşaatçılar

Sr.No Yöntem ve Açıklama
1 PatternSyntaxException(String desc, String regex, int index)

Bu sınıfın yeni bir örneğini oluşturur.

Sınıf yöntemleri

Sr.No Yöntem ve Açıklama
1 String getDescription()

Hatanın açıklamasını alır.

2 int getIndex()

Hata indeksini alır.

3 String getMessage()

Sözdizimi hatasının açıklamasını ve dizinini, hatalı normal ifade modelini ve kalıp içindeki hata dizininin görsel bir göstergesini içeren çok satırlı bir dize döndürür.

4 String getPattern()

Hatalı normal ifade modelini alır.

Miras alınan yöntemler

Bu sınıf, yöntemleri aşağıdaki sınıflardan miras alır -

  • Java.lang.Throwable
  • Java.lang.Object

Misal

Aşağıdaki örnek, java.util.regex.Pattern.PatternSyntaxException sınıfı yöntemlerinin kullanımını gösterir.

package com.tutorialspoint;

import java.util.regex.Matcher;
import java.util.regex.Pattern;
import java.util.regex.PatternSyntaxException;

public class PatternSyntaxExceptionDemo {
   private static String REGEX = "[";
   private static String INPUT = "The dog says meow " + "All dogs say meow.";
   private static String REPLACE = "cat";

   public static void main(String[] args) {
      try{
         Pattern pattern = Pattern.compile(REGEX);
         
         // get a matcher object
         Matcher matcher = pattern.matcher(INPUT); 
         INPUT = matcher.replaceAll(REPLACE);
      } catch(PatternSyntaxException e){
         System.out.println("PatternSyntaxException: ");
         System.out.println("Description: "+ e.getDescription());
         System.out.println("Index: "+ e.getIndex());
         System.out.println("Message: "+ e.getMessage());
         System.out.println("Pattern: "+ e.getPattern());
      }
   }
}

Yukarıdaki programı derleyip çalıştıralım, bu aşağıdaki sonucu verecektir -

PatternSyntaxException: 
Description: Unclosed character class
Index: 0
Message: Unclosed character class near index 0
[
^
Pattern: [

Aşağıda, java'da normal ifade kullanan çeşitli karakter eşleştirme örnekleri verilmiştir.

Sr.No İnşa ve Maçlar
1 x

X karakteri

2 \\

Ters eğik çizgi karakteri

3 \ 0n

Sekizlik değeri 0n olan karakter (0 ≤ n ≤ 7)

4 \ 0nn

Sekizlik değeri 0nn olan karakter (0 ≤ n ≤ 7)

5 \ 0mnn

Sekizlik değeri 0mnn olan karakter (0 ≤ m ≤ 3, 0 ≤ n ≤ 7)

6 \ xhh

Onaltılık değeri 0xhh olan karakter

7 \ uhhhh

Onaltılık değeri 0xhhhh olan karakter

8 \ t

Sekme karakteri ('\ u0009')

9 \ n

Yeni satır (satır besleme) karakteri ('\ u000A')

10 \ r

Satır başı karakteri ('\ u000D')

11 \ f

Form besleme karakteri ('\ u000C')

Aşağıda, java'da düzenli ifade kullanan çeşitli karakter sınıfları örnekleri verilmiştir.

Sr.No İnşa ve Maçlar
1 [ABC]

a, b veya c (basit sınıf).

2 [^ abc]

A, b veya c (olumsuzluk) dışında herhangi bir karakter.

3 [a-zA-Z]

a'dan z'ye veya A'dan Z'ye, dahil (aralık).

4 [reklam [mp]]

a'dan d'ye veya m'den p'ye: [a-dm-p] (birleşim).

5 [az && [def]]

d, e veya f (kesişim).

6 [az && [^ bc]]

a'dan z'ye, b ve c hariç: [ad-z] (çıkarma)

7 [az && [^ mp]]

a'dan z'ye, m'den p'ye değil: [a-lq-z] (çıkarma).

Aşağıda, java'da düzenli ifade kullanan önceden tanımlanmış karakter sınıflarını eşleştirmenin çeşitli örnekleri verilmiştir.

Sr.No İnşa ve Maçlar
1 .

Herhangi bir karakter (satır sonlandırıcılarla eşleşebilir veya eşleşmeyebilir).

2 \ d

Bir rakam: [0-9].

3 \ D

Rakam olmayan: [^ 0-9].

4 \ s

Bir boşluk karakteri: [\ t \ n \ x0B \ f \ r]

5 \ S

Boşluk olmayan bir karakter: [^ \ s].

6 \ w

Bir kelime karakteri: [a-zA-Z_0-9].

7 \ W

Sözcük olmayan bir karakter: [^ \ w]

Aşağıda, java'da düzenli ifade kullanan çeşitli POSIX karakter sınıfları örnekleri verilmiştir.

Sr.No İnşa ve Maçlar
1 \ p {Aşağı}

Küçük harf alfabetik karakter: [az].

2 \ p {Yukarı}

Bir büyük harf alfabetik karakter: [AZ].

3 \ p {ASCII}

Tüm ASCII: [\ x00- \ x7F].

4 \ p {Alpha}

Alfabetik bir karakter: [\ p {Alt} \ p {Üst}].

5 \ p {Basamak}

Ondalık basamak: [0-9].

6 \ p {Alnum}

Alfasayısal bir karakter: [\ p {Alpha} \ p {Digit}].

7 \ p {Noktalama}

Noktalama:! "# $% & '() * +, -. / :; <=>? @ [\] ^ _> {|} <.

8 \ p {Graph}

Görünür bir karakter: [\ p {Alnum} \ p {Punct}].

9 \ p {Yazdır}

Yazdırılabilir bir karakter: [\ p {Graph} \ x20].

10 \ p {Boş}

Bir boşluk veya sekme: [\ t].

11 \ p {XDigit}

Onaltılık bir rakam: [0-9a-fA-F].

12 \ p {Boşluk}

Bir boşluk karakteri: [\ t \ n \ x0B \ f \ r].

Aşağıda, java'da normal ifade kullanan JAVA karakter sınıflarını eşleştirmenin çeşitli örnekleri verilmiştir.

Sr.No İnşa ve Maçlar
1 \ p {javaLowerCase}

Java.lang.Character.isLowerCase () ile eşdeğerdir.

2 \ p {javaUpperCase}

Java.lang.Character.isUpperCase () ile eşdeğerdir.

3 \ p {javaWhitespace}

Java.lang.Character.isWhitespace () ile eşdeğerdir.

4 \ p {javaMirrored}

Java.lang.Character.isMirrored () ile eşdeğerdir.

Aşağıda, java'da normal ifade kullanan Unicode karakter sınıflarını eşleştirmenin çeşitli örnekleri verilmiştir.

Sr.No İnşa ve Maçlar
1 \ p {IsLatin}

Latin alfabesi karakter.

2 \ p {InGreek}

Yunan bloğunda bir karakter.

3 \ p {Lu}

Bir büyük harf.

4 \ p {IsAlphabetic}

Alfabetik bir karakter (ikili özellik).

5 \ p {Sc}

Para birimi simgesi.

6 \ P {InGreek}

Yunan bloğundaki biri dışında herhangi bir karakter.

7 [\ p {L} ve& [^ \ p {Lu}]]

Büyük harf dışında herhangi bir harf.

Aşağıda, java'da normal ifadeyi kullanan çeşitli Sınır Eşleştirici örnekleri verilmiştir.

Sr.No İnşa ve Maçlar
1 ^

Bir satırın başlangıcı.

2 $

Bir satırın sonu.

3 \ b

Bir kelime sınırı.

4 \ B

Sözcük olmayan bir sınır.

5 \ A

Girişin başlangıcı.

6 \ G

Önceki maçın sonu.

7 \ Z

Girdinin sonu, ancak varsa son sonlandırıcı içindir.

8 \ z

Girişin sonu.

Açgözlü bir nicelik belirteci, arama motorunun tüm dizeyi aramasını ve verilen normal ifadeyle eşleşip eşleşmediğini kontrol etmesini belirtir. Aşağıda, java'da normal ifadeyi kullanan çeşitli Greedy Quantifiers örnekleri verilmiştir.

Sr.No İnşa ve Maçlar
1 X?

X, bir kez ya da hiç.

2 X *

X, sıfır veya daha fazla kez

3 X +

X, bir veya daha fazla kez.

4 X {n}

X, tam olarak n kez.

5 X {n,}

X, en az n kez.

6 X {n, m}

X, en az n, en fazla m kez

İsteksiz bir nicelik belirteci, arama motorunun dizenin mümkün olan en kısa parçasıyla başlaması gerektiğini belirtir. Eşleşme bulunduğunda, motor devam eder; aksi takdirde, dizenin kontrol edilen bölümüne bir karakter ekler ve onu arar, vb. Bu süreç, bir eşleşme bulana veya dizenin tamamı bitene kadar devam eder. Aşağıda, java'da düzenli ifade kullanan İsteksiz Nicelik Belirleyicilerin çeşitli örnekleri verilmiştir.

Sr.No İnşa ve Maçlar
1 X ??

X, bir kez ya da hiç.

2 X *?

X, sıfır veya daha fazla kez

3 X +?

X, bir veya daha fazla kez.

4 X {n}?

X, tam olarak n kez.

5 X {n,}?

X, en az n kez.

6 X {n, m}?

X, en az n, en fazla m kez

Bir iyelik nicelik belirteci, açgözlü niceleyiciye benzer. Dizginin tamamını kontrol ederek motorun çalışacağını belirtir. Çalışmıyorsa, eşleşmiyorsa ve geriye bakılmıyorsa farklıdır. Aşağıda, java'da normal ifade kullanan çeşitli İyelik Niceleyiciler örnekleri verilmiştir.

Sr.No İnşa ve Maçlar
1 X? +

X, bir kez ya da hiç.

2 X * +

X, sıfır veya daha fazla kez

3 X ++

X, bir veya daha fazla kez.

4 X {n} +

X, tam olarak n kez.

5 X {n,} +

X, en az n kez.

6 X {n, m} +

X, en az n, en fazla m kez

Aşağıda, java'da normal ifade kullanan çeşitli Mantıksal Operatör örnekleri verilmiştir.

Sr.No İnşa ve Maçlar
1 XY

X ve ardından Y.

2 X | Y

Ya X ya da Y

Yazdır