PHPでよく使われる正規表現

Jan 30, 2020 pm 10:30 PM
正規表現

PHPでよく使われる正規表現

正規表現は、Web サイトを作成するときによく使用されます。ここでは、参照および変更のみを目的として、いくつかの説明と例を示します:

数字の照合

"^\d $" //非負の整数 (正の整数 0)

"^[0-9]*[1-9][0-9] *$ " //正の整数

"^((-\d )|(0 ))$" //非正の整数(負の整数0)

"^-[0- 9 ]*[1-9][0-9]*$" // 負の整数

"^-?\d $" // 整数

"^\d (\. \ d )?$" //非負の浮動小数点数 (正の浮動小数点数 0)

"^(([0-9] \.[0-9]*[1-9][0 -9 ]*)|([0-9]*[1-9][0-9]*\.[0-9] )|([0-9]*[1-9][0-9] *) )$" //正の浮動小数点数

"^((-\d (\.\d )?)|(0 (\.0 )?))$" //非正浮動小数点数 (負の浮動小数点数 0)

"^((([0-9] \.[0-9]*[1-9][0-9]*)|([ 0-9]*[ 1-9][0-9]*\.[0-9] )|([0-9]*[1-9][0-9]*)))$" //負の浮動小数点数

"^(-?\d )(\.\d )?$" //浮動小数点数

一致文字

"^[A -Za-z] $" / /英大文字26文字からなる文字列

"^[A-Z] $" //英大文字26文字からなる文字列

"^[ a-z] $" / /英小文字26文字からなる文字列

"^[A-Za-z0-9] $" //数字と英文字26文字からなる文字列

"^\w $" //数字、26 個の英字、またはアンダースコアで構成される文字列

一致例

"^[\w-] (\.[\w-] )* @[\w-] (\.[\w-] ) $" //メールアドレス

"^[a-zA-z] ://(\w (-\w )* )( \.(\w (-\w )*))*(\?\S*)?$" //url

/^(d{2}|d{4} )- ((0([1-9]{1}))|(1[1|2]))-(([0-2]([1-9]{1}))|(3[0 |1 ]))$/ // 年-月-日

/^((0([1-9]{1}))|(1[1 |2 ]))/(([0-2]([1-9]{1}))|(3[0|1]))/(d{2}|d{4})$/ // 月/日/年

"^([w-.] )@(([[0-9]{1,3}.[0-9]{ 1, 3}.[0-9]{1,3}.)|(([w-] .) ))([a-zA-Z]{2,4}|[0-9]{1, 3} )(]?)$" //エミル

/^((\ ?[0-9]{2,4}\-[0-9] {3 ,4}\-)|([0-9]{3,4}\-))?([0-9]{7,8})(\-[0-9] )?$/ / /電話

#"^(d{1,2}|1dd|2[0-4]d|25[0-5]).(d{1 ,2 }|1dd|2[0-4]d|25[0-5]).(d{1,2}|1dd|2[0-4]d|25[0-5]).(d {1 ,2}|1dd|2[0-4]d|25[0-5])$" //IP アドレス

その他の一致

#中国語の文字と一致する正規表現: [\u4e00-\u9fa5]

# 2 バイト文字 ((内) 内の中国語文字を含む) と一致します。 : [^\x00-\xff]


空行に一致する正規表現:\n[\s| ]*\r


HTML タグに一致する正規表現: /<(.*)>.*<\ 1="">|<(.*)>/


先頭および末尾のスペースに一致する正規表現: (^\s*)|(\s*$)


電子メールに一致するアドレスの正規表現: \ w ([- .]\w )*@\w ([-.]\w )*\.\w ([-.]\w )*


URL に一致する正規表現: ^[a-zA-z] ://(\\w (-\\w )*)(\\.(\\w (-\\ w )*))*(\\? \\S*)?$


一致するアカウントは合法ですか (文字で始まり、5 ~ 16 バイトが許可され、英数字が許可されます。下線): ^[a-zA- Z][a-zA-Z0-9_]{4,15}$


国内電話番号の一致: (\d{3}- |\d{4}-)? (\d{8}|\d{7})?

Tencent QQ 番号と一致します: ^[1-9]*[1-9][0-9 ]*$

正規表現のコンテキストでのメタ文字とその動作:

\ 次の文字を特殊文字、リテラル文字、後方参照、または 8 進エスケープ文字としてマークします。

#^ 入力文字列の先頭と一致します。 RegExp オブジェクトの Multiline プロパティが設定されている場合、^ は '\n' または '\r' の後の位置にも一致します。

$ 入力文字列の末尾と一致します。 RegExp オブジェクトの Multiline プロパティが設定されている場合、$ は '\n' または '\r' の前の位置にも一致します。

* 前の部分式と 0 回以上一致します。

前の部分式と 1 回以上一致します。 {1,} と同等。

? 直前の部分式と 0 回または 1 回一致します。 ? {0,1} に相当します。

{n} n は、特定の回数 n 回一致する非負の整数です。

{n,} n は負ではない整数で、少なくとも n 回一致します。

{n,m} m と n は両方とも非負の整数であり、n ? この文字が他の修飾子 (*、 、 ?、 {n}、 {n,}、 {n,m}) のすぐ後に続く場合、一致パターンは非貪欲です。非貪欲モードは検索文字列の可能な限り少ない部分と一致しますが、デフォルトの貪欲モードは検索文字列の可能な限り多くの部分と一致します。

.「\n」を除く任意の 1 文字と一致します。 「\n」を含む任意の文字と一致するには、「[.\n]」のようなパターンを使用します。

(パターン) パターンに一致し、この一致を取得します。

(?:pattern) はパターンに一致しますが、一致結果は取得されません。これは、これは非取得一致であり、後で使用するために保存されないことを意味します。

(?=パターン) 前方参照。文字列一致パターンの先頭にある検索文字列と一致します。これは非フェッチ一致です。つまり、後で使用するために一致をフェッチする必要はありません。

(?!pattern) (?=pattern) の反対の負の検索。

x|y は x または y と一致します。

[xyz] 文字セット。

[^xyz] 負の文字セット。

[a-z] 文字範囲。指定された範囲内の任意の文字と一致します。

[^a-z] 負の文字範囲。指定された範囲内にない任意の文字と一致します。

\b は、単語とスペースの間の位置を指す単語境界に一致します。

\B 単語以外の境界と一致します。

\cx は、x で指定された制御文字と一致します。

\d は数字と一致します。 [0-9]に相当します。

\D は数字以外の文字と一致します。 [^0-9] に相当します。

\f はフォーム フィード文字と一致します。 \x0c および \cL に相当します。

\n は改行文字と一致します。 \x0a および \cJ に相当します。

\r は復帰文字と一致します。 \x0d および \cM に相当します。

\s は、スペース、タブ、フォーム フィードなどを含む任意の空白文字と一致します。 [ \f\n\r\t\v] と同等。

\S は空白以外の文字に一致します。 [^ \f\n\r\t\v] と同等。

\t はタブ文字と一致します。 \x09 および \cI に相当します。

\v は垂直タブ文字と一致します。 \x0b および \cK に相当します。

\w アンダースコアを含む任意の単語文字と一致します。 「[A-Za-z0-9_]」と同等。

\W は、単語以外の文字に一致します。 「[^A-Za-z0-9_]」と同等。

\xn は n と一致します。n は 16 進数のエスケープ値です。 16 進エスケープ値は正確に 2 桁の長さである必要があります。

\num は num と一致します。ここで、num は正の整数です。取得した一致への参照。

\n 8 進エスケープ値または後方参照を識別します。 \n の前に少なくとも n 個のフェッチされた部分式がある場合、n は後方参照です。それ以外の場合、n が 8 進数 (0 ~ 7) の場合、n は 8 進数のエスケープ値になります。

\nm 8 進エスケープ値または後方参照を識別します。 \nm の前に少なくとも nm 個のフェッチされた部分式がある場合、nm は後方参照です。 \nm の前に少なくとも n の get がある場合、n は後方参照であり、その後にリテラル m が続きます。前の条件がどちらも true でない場合、n と m が両方とも 8 進数 (0 ~ 7) であれば、\nm は 8 進数のエスケープ値 nm と一致します。

\nml n が 8 進数 (0 ~ 3) で、m と l が両方とも 8 進数 (0 ~ 7) の場合、8 進数のエスケープ値 nml と一致します。

\un は n と一致します。n は 4 桁の 16 進数で表される Unicode 文字です。

中国語の文字に一致する正規表現: [u4e00-u9fa5]

一致する 2 バイト文字 (中国語の文字を含む): [^x00-xff]

# Regular空行に一致する式: n[s| ]*r

HTML タグに一致する正規表現: /<(.*)>. *|<(.* )>/

先頭と末尾のスペースに一致する正規表現: (^s*)|(s*$)

電子メール アドレスに一致する正規表現: w ([- .]w )*@w ([-.]w )*.w ([-.]w )*

URL に一致する正規表現: http://([w-] .) [w-] (/[w- ./?%&=]*)?

正規表現を使用して、Web フォームのテキスト ボックスの入力内容を制限します:

正規表現を使用して、中国語を入力できることのみを制限します: onkeyup="value= value.replace(/[^u4E00-u9FA5]/g,'')" onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/ [^u4E00-u9FA5]/g, ''))"

正規表現を使用して全角文字のみの入力を制限します: onkeyup="value=value.replace(/ [^uFF00-uFFFF] /g,'')" onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^uFF00-uFFFF]/g,''))"

正規表現を使用して入力を数値に制限します: onkeyup="value=value.replace(/[^d]/g,'') "onbeforepaste="clipboardData .setData('text', ClipboardData.getData('text').replace(/[^d]/g,''))"

正規表現を使用する 数字と英語のみを入力できます: onkeyup="value=value.replace(/[W]/g,'') "onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace( /[^d]/g, ''))"

一般的に使用される通常の例

1. 負でない整数: ^\d $

2. 正の整数: ^[0-9]*[1-9][0-9]*$

3. 非正整数:^((-\d )|(0 ))$

4、負の整数: ^-[0-9]*[1-9][0 - 9]*$

5. 整数: ^-?\d $

6. 非負浮動小数点数:^\d (\.\d )?$

7、正の浮動小数点数: ^((0-9) \.[0-9 ]*[1 -9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9] )|([0-9]*[ 1-9] [0-9]*))$

8. 非正の浮動小数点数: ^((-\d \.\d )?) |(0 (\. 0 )?))$

9. 負の浮動小数点数: ^(-((正の浮動小数点数正規表現)))$

10. 英語の文字列: ^[A-Za-z] $

##11. 英語の大文字の文字列: ^[ A-Z] $

12. 英語の小文字の文字列: ^[a-z] $

13. 英語の文字列: ^[A-Za -z0-9] $

14. 英数字と下線付きの文字列: ^\w $

#15. 電子メール アドレス: ^[\w-] (\.[\w-] )*@[\w-] (\.[\w-] ) $

#16. URL: ^[a-zA-Z] ://(\w (-\w )*)(\.(\w (-\w )*))*(\?\s *)? $


または: ^http:\/\/[A-Za-z0-9] \.[A-Za-z0-9] [\ /=\ ?%\-&_~`@[\]\': !]*([^<>\"\"])*$


##17 、ポストコーディング: ^[1-9]\d{5}$


18、中国語: ^[\u0391-\uFFE5] $


19. 電話番号: ^((\(\d{2,3}\))|(\d{3}\-))?(\(0\d{2, 3} \)|0\d{2,3}-)?[1-9]\d{6,7}(\-\d{1,4})?$


20. 携帯電話番号: ^((\(\d{2,3}\))|(\d{3}\-))?13\d{9}$


21. 全角文字 (漢字を含む): ^\x00-\xff


22. 先頭と末尾の一致スペース: (^ \s*)|(\s*$) (vbscript のようなトリム関数)


23. HTML タグに一致: <(.*)> .* <\ 1="">|<(.*)>


##24. 空行と一致します: \n[\s| ]*\r


25. 情報内のネットワーク リンクを抽出します: (h|H)(r|R)(e|E)(f|F) *= *('| " )?(\w|\\|\/|\.) ('|"| *|>)?


26.情報: \w ([- .]\w )*@\w ([-.]\w )*\.\w ([-.]\w )*


27. 情報内の画像リンクを抽出します: (s|S)(r|R)(c|C) *= *('|")?(\w|\\|\/|\.) ('| "| *|>)?


28. 情報内の IP アドレスを抽出します: (\d )\.(\d )\.(\ d )\. (\d )


29. 情報内の中国の携帯電話番号を抽出します: (86)*0*13\d{9}


30. 情報から中国の固定電話番号を抽出します: (\(\d{3,4}\)|\d{3,4}-|\s)? \d{8}


31. 情報 (携帯電話と固定電話を含む) 内の中国の電話番号を抽出します: (\(\d{3,4}\)| \d{3,4} -|\s)?\d{7,14}


32. 情報内の中国の郵便番号を抽出します: [1-9] ]{1}(\d ) {5}


33. 情報内の浮動小数点数 (つまり、10 進数) を抽出します: (-?\d*)\.? \d


34. 情報内の任意の数値を抽出します: (-?\d*)(\.\d )?


35. IP: (\d )\.(\d )\.(\d )\.(\d )


36、電話エリアコード: /^0\d{2, 3}$/


37、テンセント QQ 番号: ^[1-9]*[1-9][0- 9]*$


38. アカウント番号 (文字で始まり、5 ~ 16 バイト、英数字のアンダースコアを使用可能): ^[a-zA-Z][a -zA-Z0-9_]{4,15 }$

##39、中国語、英語、数字、下線: ^[\u4e00-\u9fa5_a-zA-Z0-9 ] $

##追加

中国語の文字に一致する正規表現: [\u4e00-\u9fa5]

2 バイト文字 (漢字を含む) に一致します: [^\x00-\xff]

空白に一致する正規表現行:\n[\ s| ]*\r

HTML タグに一致する正規表現: /<(.*)>.*<\ 1=" ">| <(.*)>/

先頭および末尾のスペースに一致する正規表現: (^\s*)|(\s*$)

IP アドレスに一致する正規表現: /(\ d ) \.(\d )\.(\d )\.(\d )/g //

電子メール アドレスに一致する正規表現:\w ( [- .] \w )*@\w ([-.]\w )*\.\w ([-.]\w )*

URL の一致 URL の正規表現: http://(/[\w-] \.) [\w-] (/[\w- ./?%&=]*)?

sql ステートメント: ^(select|drop|delete|create|update|insert).*$

以上がPHPでよく使われる正規表現の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

PHP 正規表現の検証: 数値形式の検出 PHP 正規表現の検証: 数値形式の検出 Mar 21, 2024 am 09:45 AM

PHP 正規表現の検証: 数値形式の検出 PHP プログラムを作成する場合、ユーザーが入力したデータを検証する必要がよくあります。一般的な検証の 1 つは、データが指定された数値形式に準拠しているかどうかを確認することです。 PHP では、正規表現を使用してこの種の検証を行うことができます。この記事では、PHP 正規表現を使用して数値形式を検証する方法を紹介し、具体的なコード例を示します。まず、一般的な数値形式の検証要件を見てみましょう。 整数: 0 ~ 9 の数字のみが含まれ、プラスまたはマイナス記号で始めることができ、小数点は含まれません。浮動小数点

正規表現を使用して Golang でメールアドレスを検証するにはどうすればよいですか? 正規表現を使用して Golang でメールアドレスを検証するにはどうすればよいですか? May 31, 2024 pm 01:04 PM

正規表現を使用して Golang で電子メール アドレスを検証するには、次の手順に従います。 regexp.MustCompile を使用して、有効な電子メール アドレス形式と一致する正規表現パターンを作成します。 MatchString 関数を使用して、文字列がパターンと一致するかどうかを確認します。このパターンは、次のようなほとんどの有効な電子メール アドレス形式をカバーします。 ローカル ユーザー名には文字、数字、および特殊文字を含めることができます: !.#$%&'*+/=?^_{|}~-` ドメイン名には少なくとも次の文字が含まれている必要があります。 1 文字の後に文字、数字、またはハイフンを続けます。トップレベル ドメイン (TLD) は 63 文字を超えることはできません。

Go で正規表現を使用してタイムスタンプを照合するにはどうすればよいですか? Go で正規表現を使用してタイムスタンプを照合するにはどうすればよいですか? Jun 02, 2024 am 09:00 AM

Go では、正規表現を使用してタイムスタンプを照合できます。ISO8601 タイムスタンプの照合に使用されるような正規表現文字列をコンパイルします。 ^\d{4}-\d{2}-\d{2}T \d{ 2}:\d{2}:\d{2}(\.\d+)?(Z|[+-][0-9]{2}:[0-9]{2})$ 。 regexp.MatchString 関数を使用して、文字列が正規表現と一致するかどうかを確認します。

Go言語の正規表現と文字列処理をマスターする Go言語の正規表現と文字列処理をマスターする Nov 30, 2023 am 09:54 AM

最新のプログラミング言語として、Go 言語は強力な正規表現と文字列処理関数を提供し、開発者が文字列データをより効率的に処理できるようにします。開発者にとって、Go 言語での正規表現と文字列処理を習得することは非常に重要です。この記事では、Go 言語の正規表現の基本概念と使い方、Go 言語を使用して文字列を処理する方法を詳しく紹介します。 1. 正規表現 正規表現は文字列のパターンを記述するためのツールであり、文字列の照合、検索、置換などの操作を簡単に実装できます。

PHP 正規表現: 厳密な一致とあいまいな包含の除外 PHP 正規表現: 厳密な一致とあいまいな包含の除外 Feb 28, 2024 pm 01:03 PM

PHP 正規表現: 完全一致と除外 ファジー包含正規表現は、プログラマがテキストを処理する際に効率的な検索、置換、フィルタリングを実行できる強力なテキスト マッチング ツールです。 PHP では、正規表現は文字列処理やデータ マッチングにも広く使用されています。この記事では、PHP で完全一致を実行し、あいまい包含操作を除外する方法に焦点を当て、具体的なコード例を使用して説明します。完全一致 完全一致とは、バリエーションや余分な単語ではなく、正確な条件を満たす文字列のみと一致することを意味します。

Goで正規表現を使用してパスワードを確認するにはどうすればよいですか? Goで正規表現を使用してパスワードを確認するにはどうすればよいですか? Jun 02, 2024 pm 07:31 PM

Go で正規表現を使用してパスワードを検証する方法は次のとおりです。 パスワードの最小要件 (小文字、大文字、数字、特殊文字を含む少なくとも 8 文字) を満たす正規表現パターンを定義します。 regexp パッケージの MustCompile 関数を使用して正規表現パターンをコンパイルします。 MatchString メソッドを使用して、入力文字列が正規表現パターンと一致するかどうかをテストします。

正規表現のワイルドカードとは何ですか? 正規表現のワイルドカードとは何ですか? Nov 17, 2023 pm 01:40 PM

正規表現のワイルドカードには、「.」、「*」、「+」、「?」、「^」、「$」、「[]」、「[^]」、「[a-z]」、「[A-Z]」が含まれます。 、"[0-9]"、"\d"、"\D"、"\w"、"\W"、"\s&quo

漢字フィルタリング: PHP 正規表現の練習 漢字フィルタリング: PHP 正規表現の練習 Mar 24, 2024 pm 04:48 PM

PHP は広く使用されているプログラミング言語であり、特に Web 開発の分野で人気があります。 Web開発の過程では、ユーザーが入力したテキストをフィルタリングして検証する必要がよくありますが、その中でも文字フィルタリングは非常に重要な操作です。この記事では、PHP で正規表現を使用して漢字フィルタリングを実装する方法と、具体的なコード例を紹介します。まず最初に、Unicode の漢字の範囲は u4e00 から u9fa5 までである、つまりすべての漢字がこの範囲内にあることを明確にする必要があります。

See all articles