VBScript - Normal İfadeler

Normal İfadeler, esas olarak arama ve değiştirme için kullanılan, bir kalıp oluşturan bir karakter dizisidir. Bir kalıp oluşturmanın amacı, geliştiricinin koşullara göre karakterleri çıkarabilmesi ve belirli karakterleri değiştirebilmesi için belirli dizeleri eşleştirmektir.

RegExp Nesnesi

RegExp nesnesi, geliştiricilerin dizelerin modelini eşleştirmesine yardımcı olur ve özellikler ve yöntemler, Normal İfadelerle kolayca çalışmamıza yardımcı olur. JavaScript'teki RegExp'e benzer

Özellikleri

  • Pattern - Pattern yöntemi, normal ifadeyi tanımlamak için kullanılan bir dizeyi temsil eder ve normal ifade nesnesi kullanılmadan önce ayarlanmalıdır.

  • IgnoreCase- Normal ifadenin doğru veya yanlışsa bir dizedeki tüm olası eşleşmelere karşı test edilip edilmeyeceğini temsil eden bir Boole özelliği. Açıkça belirtilmezse, IgnoreCase değeri False olarak ayarlanır.

  • Global- Normal ifadenin bir dizedeki tüm olası eşleşmelere karşı test edilip edilmeyeceğini temsil eden bir Boole özelliği. Açıkça belirtilmezse, Global değer False olarak ayarlanır.

Yöntemler

  • Test(arama dizesi) - Test yöntemi, bağımsız değişken olarak bir dizeyi alır ve normal ifade dizeyle başarılı bir şekilde eşleştirilebilirse True döndürür, aksi takdirde False döndürülür.

  • Replace(arama dizesi, değiştirme-dizesi) - Değiştirme yöntemi 2 parametre alır. Arama başarılı olursa, bu eşleşmeyi değiştirme dizesiyle değiştirir ve yeni dizge döndürülür. Eşleşme yoksa, orijinal arama dizesi döndürülür.

  • Execute(search-string) - Execute yöntemi, her başarılı eşleşme için bir Match nesnesi içeren bir Matches koleksiyon nesnesi döndürmesi dışında Replace gibi çalışır. Orijinal dizeyi değiştirmez.

Koleksiyon Nesnesi ile Eşleşir

Matches koleksiyon nesnesi, Execute yönteminin bir sonucu olarak döndürülür. Bu koleksiyon nesnesi sıfır veya daha fazla Match nesnesi içerebilir ve bu nesnenin özellikleri salt okunurdur.

  • Count - Count yöntemi, koleksiyondaki eşleşme nesnelerinin sayısını temsil eder.

  • Item - Öğe yöntemi, eşleşme nesnelerine, eşleşme koleksiyonları nesnesinden erişilmesini sağlar.

Eşleştirme Nesnesi

Match nesnesi, match koleksiyon nesnesinin içinde bulunur. Bu nesneler, bir dizge aramasından sonraki başarılı eşleşmeyi temsil eder.

  • FirstIndex- Eşleşmenin gerçekleştiği orijinal dize içindeki konumu temsil eder. Bu dizin sıfır tabanlıdır, yani bir dizedeki ilk konum 0'dır.

  • Length - Eşleşen dizenin toplam uzunluğunu temsil eden bir değer.

  • Value- Eşleşen değeri veya metni temsil eden bir değer. Aynı zamanda Match nesnesine erişirken varsayılan değerdir.

Desen Parametresi hakkında her şey

Desen oluşturma PERL'e benzer. Düzenli İfadeler ile çalışırken desen oluşturma en önemli şeydir. Bu bölümde, çeşitli faktörlere dayalı bir modelin nasıl oluşturulacağını ele alacağız.

Pozisyon Eşleştirme

Konum eşleştirmenin önemi, normal ifadeleri doğru yerlere yerleştirmemizi sağlamaktır.

Sembol Açıklama
^ Bir dizenin yalnızca başlangıcıyla eşleşir.
$ Bir dizenin yalnızca sonunu eşleştirin.
\ b Herhangi bir kelime sınırıyla eşleşir
\ B Sözcük olmayan herhangi bir sınırla eşleşir

Değişmezler Eşleşiyor

Alfabe, sayı veya özel karakter veya hatta ondalık, onaltılık gibi herhangi bir karakter biçimi, Değişmez Değer olarak kabul edilebilir. Normal İfade bağlamında birkaç karakter zaten özel bir anlama sahip olduğundan, kaçış dizilerini kullanarak onlardan kaçmamız gerekir.

Sembol Açıklama
Alfasayısal Yalnızca alfabetik ve sayısal karakterlerle eşleşir.
\ n Yeni bir satırla eşleşir.
\ [ Eşleşmeler [yalnızca değişmez
\] Matches] yalnızca gerçek
\ ( Eşleşmeler (yalnızca değişmez
\) Maçlar) yalnızca değişmez
\ t Yatay sekmeyle eşleşir
\ v Dikey sekmeyle eşleşir
\ | Maçlar | sadece gerçek
\ { {Literal only ile eşleşir
\} Yalnızca Matches} değişmez
\\ Yalnızca değişmez \ eşleşir
\? Maçlar ? sadece gerçek
\ * Yalnızca değişmez * eşleşir
\ + Eşleşir + yalnızca değişmez
\. Maçlar . sadece gerçek
\ b Herhangi bir kelime sınırıyla eşleşir
\ B Sözcük olmayan herhangi bir sınırla eşleşir
\ f Bir form beslemesiyle eşleşir
\ r Satır başı ile eşleşir
\ xxx Bir xxx sekizlik sayısının ASCII karakteriyle eşleşir.
\ xdd Onaltılık sayı dd'nin ASCII karakteriyle eşleşir.
\ uxxxx Bir UNICODE değişmez değeri xxxx'in ASCII karakteriyle eşleşir.

Eşleşen Karakter Sınıfları

Karakter sınıfları, özelleştirilmiş gruplamayla oluşturulan ve [] parantez içine alınmış Desendir. Listede olmaması gereken bir karakter sınıfı bekliyorsak, o zaman negatif sembolü kullanan o belirli karakter sınıfını yok saymalıyız, bu bir cap ^ olan.

Sembol Açıklama
[xyz] Karakter kümesinde yer alan herhangi bir karakter sınıfıyla eşleşir.
[^ xyz] Karakter kümesine dahil OLMAYAN herhangi bir karakter sınıfıyla eşleşir.
. \ N dışında herhangi bir karakter sınıfıyla eşleşir
\ w Herhangi bir kelime karakter sınıfıyla eşleştirin. [A-zA-Z_0-9] ile eşdeğerdir
\ W Sözcük olmayan herhangi bir karakter sınıfıyla eşleştirin. [^ A-zA-Z_0-9] ile eşdeğerdir
\ d Herhangi bir rakam sınıfıyla eşleştirin. [0-9] ile eşdeğerdir.
\ D Rakam olmayan herhangi bir karakter sınıfıyla eşleştirin. [^ 0-9] ile eşdeğerdir.
\ s Herhangi bir boşluk karakteri sınıfıyla eşleşir. [\ T \ r \ n \ v \ f] ile eşdeğerdir
\ S Herhangi bir boşluk karakteri sınıfıyla eşleşir. [^ \ T \ r \ n \ v \ f] ile eşdeğerdir

Tekrar Eşleştirme

Tekrar eşleştirme, normal ifade içinde birden çok aramaya izin verir. Ayrıca, bir Normal İfadede bir öğenin tekrarlanma sayısını da belirtir.

Sembol Açıklama
* Verilen normal İfadenin sıfır veya daha fazla oluşumuyla eşleşir. {0,} ile eşdeğerdir.
+ Verilen normal İfadenin bir veya daha fazla oluşumuyla eşleşir. {1,} ile eşdeğerdir.
? Verilen normal İfadenin sıfır veya bir oluşumuyla eşleşir. {0,1} ile eşdeğerdir.
{x} Verilen düzenli ifadenin tam olarak x sayıda oluşumuyla eşleşir.
{x,} Verilen düzenli ifadenin en az x veya daha fazla tekrarı ile eşleştirin.
{x, y} Verilen düzenli ifadenin x ile y arasındaki sayıda oluşumla eşleşir.

Değişim ve Gruplama

Değişim ve gruplama, geliştiricilerin, büyük bir esneklik ve kontrol sağlayan bir Normal İfade içindeki karmaşık cümleleri özellikle işlerken daha karmaşık Normal İfadeler oluşturmalarına yardımcı olur.

Sembol Açıklama
0 Bir cümle oluşturmak için bir cümleci gruplandırma. "(xy)? (z)", "xyz" veya "z" ile eşleşir.
| Değişim, bir normal ifade cümlesini birleştirir ve ardından tek tek cümlelerin herhangi biriyle eşleşir. "(ij) | (23) | (pq)", "ij" veya "23" veya "pq" ile eşleşir.

Normal İfadeler Oluşturma

Aşağıda, Düzenli İfadenin nasıl oluşturulacağını açıkça açıklayan birkaç örnek verilmiştir.

Düzenli ifade Açıklama
"^ \ s * .." ve ".. \ s * $" Tek bir satırda herhangi bir sayıda baştaki ve sondaki boşluk karakteri olabileceğini temsil eder.
"((\ $ \ s?) | (# \ s?))?" İsteğe bağlı bir $ veya # işaretini ve ardından isteğe bağlı bir boşluğu temsil eder.
"((\ d + (\. (\ d \ d)?)?))" En az bir rakamın mevcut olduğunu ve ardından isteğe bağlı ondalık sayıların ve ondalık sayılardan sonra iki rakamın mevcut olduğunu gösterir.

Misal

Aşağıdaki örnek, kullanıcının formatı bir e-posta kimliği ve ardından '@' ve ardından alan adı olacak şekilde eşleşmesi gereken bir e-posta kimliği girip girmediğini kontrol eder.

<!DOCTYPE html>
<html>
   <body>
      <script language = "vbscript" type = "text/vbscript">
         strid = "[email protected]"
         Set re = New RegExp
         With re
            .Pattern    = "^[\w-\.]{1,}\@([\da-zA-Z-]{1,}\.){1,}[\da-zA-Z-]{2,3}$"
            .IgnoreCase = False
            .Global     = False
         End With
        
         ' Test method returns TRUE if a match is found
         If re.Test( strid ) Then
            Document.write(strid & " is a valid e-mail address")
         Else
            Document.write(strid & " is NOT a valid e-mail address")
         End If
        
        Set re = Nothing
      </script>
   </body>
</html>