PHP 正規表現の関数 以前に preg_match 関数を作成しましたので、皆さんもある程度はご存じだと思いますが、PHP 正規表現での preg_match_all 関数の具体的な用途は何でしょうか。今回はPHP正規表現のpreg_match_all関数について詳しく解説していきます!
正規表現を理解する前に、一般的に使用される正規表現についての基本的な知識を習得する必要があります。覚えていない場合は、必要なときに調べることができます。使用するのは 特殊文字 だけなので、正規表現は特別です。詳細については、詳細な手順を参照してください。
preg_match_all 関数の詳細な手順については、PHP マニュアルを確認してください。この記事では、preg_match_all を使用して正規表現の効果をテストします。
コード例:
$html = '<p id="biuuu">jb51.net</p><p id="biuuu_2">jb51.net2</p><p id="biuuu_3">jb51.net3</p>';
要件の例: biuuu、biuuu_2、biuuu_3、jb51.net、jb51.net2、jb51.net3 などの各 p 要素の ID とコンテンツを取り出します (一般的に使用される Web サイト取得方法の一部)
分析:
文字列は基本的なHTML要素であり、最初にID値とコンテンツ内のpを削除する方法を考えます。 jb51.net などのコンテンツを検索し、他の同様の要素と一致させます。 p から 2 つの値、つまり 2 つの一致する式を取り出す必要があります。最初の式は ID 値 (biuuu) と一致するために使用され、2 番目の式は ID (jb51.net) の内容と一致するために使用されます。 ). 式で一般的に使用される正規表現は括弧を使用するため、前の要素は次の形式になります:
<p id="(biuuu)">(jb51.net)</p> <p id="(表达式1)">(表达式2)</p>
さて、上記の括弧を使用して、一致する必要がある領域を分割します。次のステップは、それぞれの中で一致させる方法です。式の内容、ID は文字、数字、またはアンダースコアであると推測され、これが基本となり、次のように角かっこを使用して実現できます:
式 1:
[a-zA-Z0-9_]+ (表示匹配大小写字母,数字和下划线)
次に、式 2 を照合する方法ID の内容には任意の文字を使用できますが、< または > の文字と一致しないように注意してください。これらの 2 つの文字を一致させると、後で使用されるすべての p が一致するため、; で始まる要素を除外する必要があります。つまり、次のように、< または > で始まる文字とは一致しません。
式 2:
[^<>]+ (表示不匹配<和>字符)
このようにして、一致する必要がある部分式が実現されます。一致する必要がある式も必要です。 メソッド: / '"(式 1)"'>(式 2)
/'\"([a-z0-9_]+)\"'>/<p id=\"([a-z0-9_]+)\">([^<>]+)<\/p>/
$html = '<p id="biuuu">jb51.net</p><p id="biuuu_2">jb51.net2</p><p id="biuuu_3">jb51.net3</p>'; preg_match_all('/([^<>]+)<\/p>/',$html,$result); var_dump($result);
array(3) { [0]=> array(3) { [0]=> string(30) "<p id="biuuu">jb51.net</p>" [1]=> string(33) "<p id="biuuu_2">jb51.net2</p>" [2]=> string(33) "<p id="biuuu_3">jb51.net3</p>" } [1]=> array(3) { [0]=> string(5) "biuuu" [1]=> string(7) "biuuu_2" [2]=> string(7) "biuuu_3" } [2]=> array(3) { [0]=> string(8) "jb51.net" [1]=> string(9) "jb51.net2" [2]=> string(9) "jb51.net3" } }
概要:
この記事と前の記事を読んだ後、両方の関数には独自の理解と理解があると思います。あなたの仕事です関連する推奨事項:
以上がPHP正規表現のpreg_match_all関数の詳しい説明の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。