ホームページ >バックエンド開発 >PHPチュートリアル >PHP 正規表現のキャプチャ グループと非キャプチャ グループ (詳細な説明)、php 正規表現_PHP チュートリアル
正規表現はプロジェクト開発中によく使用されます。正規表現を知ることは、すべてのプログラマにとって最も基本的なことであると言えます。初心者は、初めて正規表現に触れるとき、難しいと感じます。最近、友人がブログで書いた「PHP 正規表現」を読んで、その章のワイルドカードとデータのキャプチャに非常に興味を持ちました。この 2 つの章では、この側面を分析するために、正規表現のキャプチャ グループと非キャプチャ グループの内容も取り上げています
正規表現において(x)は「x」と一致し、一致した値を記録することを意味することがわかります。これは単に一般的な言い方であり、() キャプチャ グループ フォームのみが一致する値を記録します。非キャプチャ グループは一致するだけで、記録されません。
キャプチャグループ:
(パターン)
このフォームは最もよく見られ、キャプチャ結果を返します。グループ番号は左から右に順番に並べられます。
コードをコピーします コードは次のとおりです:
$regex = '/(ab(c)+)+d(e)?/';
$str = 'abccde';
$matches = array();
if(preg_match($regex, $str, $matches)){
Print_r($matches);
}
マッチング結果:
コードをコピーします コードは次のとおりです:
配列 ( [0] => abccde [1] => abcc [2] => c [3] => e )
(?P
コードをコピーします コードは次のとおりです:
$regex = '/(?P
$str = 'fsabcd45';
$matches = array();
if(preg_match($regex, $str, $matches)){
Print_r($matches);
}
マッチング結果:
コードをコピーします コードは次のとおりです:
Array ( [0] => fsabcd45 [group1] => fs [1] => fs [group2] => s [2] => s [group3] => d [3] =>ニ)
番号
コードをコピーします コードは次のとおりです:
$regex = '/(w)(w)21/';
$str = 'アバ';
$matches = array();
if(preg_match($regex, $str, $matches)){
Print_r($matches);
}
マッチング結果:
コードをコピーします コードは次のとおりです:
配列 ( [0] => abba [1] => a [2] => b )
ここで細かい点を見落としていたことに注意してください。最初のコードは
$regex = “/(w)(w)21/”; でした。デバッグ後、一致する結果が返されなかったことがわかりました。 ' と " の使い方の違いに注意する必要があります。
k
(?P
コードをコピーします
コードは次のとおりです:
$regex='/(?P
echo preg_match_all($regex, $str,$matches);
print_r($matches);
マッチング結果:
コードは次のとおりです:
配列 ( [0] => 配列 ( [0] => fabcf ) [名前] => 配列 ( [0] => f ) [1] => 配列 ( [0] => f ) )
非キャプチャグループ:
(?:パターン)
(パターン) との唯一の違いは、パターンに一致しますが、一致結果を取得しないことです。ここではこれ以上の例は示しません。
同じことについて実際に話す方法は他にも 4 つあります: 事前チェック。事前チェックは順方向事前チェックと逆方向事前チェックに分かれます。文字通りの理解によれば、前方参照は一致する文字列の後ろにある特定の文字が存在するかどうかを判断することであり、逆引き参照は一致する文字列の前にある特定の文字が存在するかどうかを判断することです。
前方事前チェックは、用途(?=パターン)があるかどうか、または用途(?!パターン)があるかどうかを判断します。
リバース事前チェックは、用途(?
コードをコピーします コードは次のとおりです:
$regx='/(?
$str="abcd ebcd abce ebca";
if(preg_match_all($regx, $str, $matches)){
Print_r($matches);
}
マッチング結果:
コードをコピーします コードは次のとおりです:
配列 ( [0] => 配列 ( [0] => bc) )
これら 4 つの形式を使用するかどうかは、相対一致する文字列の位置と、主張が肯定的か否定的かに注意するだけで、すぐにマスターできます。
さらに、4 つの形式の事前チェックはゼロ幅であり、マッチング時に 1 つの判定のみが行われ、いかなる位置も占有しません。 /HE(?=L)LLO/ は HELLO に一致しますが、/HE(?=L)LO/ は HELLO に一致しません。結局のところ、この 2 つはバイト数の点で一致しません。前者は 4 バイトですが、後者は 5 バイトです。
上記は、PHP における正規表現のキャプチャ グループと非キャプチャ グループの詳細な説明の全内容です。ご理解いただけると幸いです。
。