【正規表現】文字列の否定、ある文字列を含まない
「abc」という文字列で始まらない
---------------------
^(?!abc).+$
---------------------
「abc」という文字列を含まない
---------------------
^(?!.*abc).+$
---------------------
Aの直後から「abc」という文字列を含まない繰り返し
---------------------
A((?!abc).)*?
---------------------
直後に「ABC」も「XYZ」もこないY
---------------------
Y(?!(ABC|XYZ))
---------------------
↓↓もう少し詳しく理解する。↓↓
「(?!」と「)」で文字列を囲む正規表現を否定的先読みという。
これを利用すると、囲まれた文字(パターン)がある文字の直後に存在しない位置にマッチする。普通、正規表現はマッチする文字列を見つけるが、(?!――)はその位置を見つけるだけである。「^」が行頭、「$」が行末の場所を示すのと同じように(?!――)も場所を示すだけ。
次のパターンと比較すると理解しやすい。
行頭から続く文字を繰り返している
-----------------
^.*
-----------------
(Aの直後から)abcという文字列を含まない位置にある文字を繰り返している
-----------------
A((?!abc).)*
-----------------
くどいようだが赤字はあくまでも位置を示す。