電話番号検証のための包括的な正規表現
-
02-07-2019 - |
質問
電話番号を検証するための包括的な正規表現をまとめようとしています。理想的には国際形式を処理できますが、次のような米国形式も処理する必要があります。
- 1-234-567-8901
- 1-234-567-8901x1234
- 1-234-567-8901 内線1234
- 1 (234) 567-8901
- 1.234.567.8901
- 1/234/567/8901
- 12345678901
私は現在の試みで答えますが、誰かがより良い、よりエレガントなものを持っていることを願っています。
解決
より良い選択肢...非標準形式で数字を書くイギリス人の傾向に注意して、入力時に数字以外の文字をすべて削除してください (「x」と先頭の「+」記号を除く)。 +44 (0) ...
国際プレフィックスを使用するように求められた場合 (その特定のケースでは、 (0)
全体的に)。
すると、次のような値になります。
12345678901
12345678901x1234
345678901x1234
12344678901
12345678901
12345678901
12345678901
+4112345678
+441234567890
その後、表示するときに、思う存分再フォーマットしてください。例えば
1 (234) 567-8901
1 (234) 567-8901 x1234
他のヒント
これには、少なくとも北米では、と呼ばれる仕様のようなものがあることが判明しました。 ナンプ.
必要なものを正確に指定する必要があります。法的な区切り文字とは何ですか?スペース、ダッシュ、ピリオド?区切り文字は使用できませんか?区切り文字を混在させることはできますか (例: +0.111-222.3333)?内線番号 (例: 111-222-3333 x 44444) はどのように処理されますか?911 などの特別な番号についてはどうですか?市外局番はオプションになりますか、それとも必須ですか?
以下は 7 桁または 10 桁の数値の正規表現です。拡張子は許可されており、区切り文字はスペース、ダッシュ、またはピリオドです。
^(?:(?:\+?1\s*(?:[.-]\s*)?)?(?:\(\s*([2-9]1[02-9]|[2-9][02-8]1|[2-9][02-8][02-9])\s*\)|([2-9]1[02-9]|[2-9][02-8]1|[2-9][02-8][02-9]))\s*(?:[.-]\s*)?)?([2-9]1[02-9]|[2-9][02-9]1|[2-9][02-9]{2})\s*(?:[.-]\s*)?([0-9]{4})(?:\s*(?:#|x\.?|ext\.?|extension)\s*(\d+))?$
.*
ユーザーが自分の電話番号を教えたい場合は、正しく教えてくれると信頼してください。彼がそれをあなたに渡したくない場合、有効な番号の入力を強制すると、彼は競合他社のサイトに送られるか、あなたの正規表現に適合するランダムな文字列を入力することになります。代わりに、プレミアム料金のセックス ラインの番号を調べて、それを入力したくなるかもしれません。
また、次のいずれも Web サイト上の有効なエントリとみなします。
"123 456 7890 until 6pm, then 098 765 4321"
"123 456 7890 or try my mobile on 098 765 4321"
"ex-directory - mind your own business"
「」も見ることをお勧めします。lib電話番号「Googleライブラリ。それが正規表現ではないことはわかっていますが、まさにあなたが望むことを行います。
たとえば、次のことが認識されます。
15555555555
は可能な数値ですが、有効な数値ではありません。米国以外の国もサポートします。
機能のハイライト:
- 世界のすべての国/地域の電話番号を解析/フォーマット/検証します。
getNumberType
- 数値自体に基づいて数値のタイプを取得します。固定回線、モバイル、フリーダイヤル、プレミアム料金、共有コスト、VoIP、および個人番号を区別できること (可能な場合は常に)。isNumberMatch
- 2 つの数値が同じである可能性があるかどうかの信頼レベルを取得します。getExampleNumber
/getExampleNumberByType
- すべての国/地域に有効な電話番号例を提供し、必要な電話番号例のタイプを指定するオプションを提供します。isPossibleNumber
- 長さ情報のみを使用して、番号が電話番号である可能性があるかどうかを迅速に推測します。完全な検証よりもはるかに高速です。isValidNumber
- 長さとプレフィックス情報を使用して、地域の電話番号を完全に検証します。AsYouTypeFormatter
- ユーザーが各桁を入力すると、その場で電話番号をフォーマットします。findNumbers
- テキスト入力内の数字を検索します。PhoneNumberOfflineGeocoder
- 電話番号に関連する地理情報を提供します。
例
電話番号検証の最大の問題は、文化に大きく依存していることです。
- アメリカ
(408) 974–2042
です 有効 米国の番号(999) 974–2042
は 有効ではありません 米国の番号
- オーストラリア
0404 999 999
です 有効 オーストラリアの番号(02) 9999 9999
もです 有効 オーストラリアの番号(09) 9999 9999
は 有効ではありません オーストラリアの番号
正規表現は電話番号の形式をチェックするのには適していますが、実際には電話番号をチェックすることはできません。 有効 電話番号の。
電話番号をテストするための単純な正規表現をスキップし、Google のライブラリなどを使用することをお勧めします。 libphonenumber
(GitHub プロジェクトへのリンク).
libphonenumberのご紹介です!
より複雑な例の 1 つを使用すると、 1-234-567-8901 x1234
, 、わかります 以下のデータのうち libphonenumber
(オンラインデモへのリンク):
Validation Results
Result from isPossibleNumber() true
Result from isValidNumber() true
Formatting Results:
E164 format +12345678901
Original format (234) 567-8901 ext. 123
National format (234) 567-8901 ext. 123
International format +1 234-567-8901 ext. 123
Out-of-country format from US 1 (234) 567-8901 ext. 123
Out-of-country format from CH 00 1 234-567-8901 ext. 123
そのため、電話番号が有効かどうか (実際に有効です) がわかるだけでなく、ロケールで一貫した電話番号の形式も得られます。
ボーナスとして、 libphonenumber
には、電話番号の有効性をチェックするためのデータセットも多数あるため、次のような番号をチェックします。 +61299999999
(国際版の (02) 9999 9999
) は、次の形式で有効な数値として返されます。
Validation Results
Result from isPossibleNumber() true
Result from isValidNumber() true
Formatting Results
E164 format +61299999999
Original format 61 2 9999 9999
National format (02) 9999 9999
International format +61 2 9999 9999
Out-of-country format from US 011 61 2 9999 9999
Out-of-country format from CH 00 61 2 9999 9999
libphonenumber には、電話番号が検出された場所を取得したり、電話番号からタイムゾーン情報を取得したりするなど、多くの追加の利点もあります。
PhoneNumberOfflineGeocoder Results
Location Australia
PhoneNumberToTimeZonesMapper Results
Time zone(s) [Australia/Sydney]
ただし、オーストラリアの無効な電話番号 ((09) 9999 9999
) は、有効な電話番号ではないことを返します。
Validation Results
Result from isPossibleNumber() true
Result from isValidNumber() false
Google のバージョンには Java と Javascript 用のコードが含まれていますが、Google i18n 電話番号データセットを使用する他の言語用のライブラリも実装されています。
- PHP: https://github.com/giggsey/libphonenumber-for-php
- パイソン: https://github.com/daviddrysdale/python-phonenumbers
- ルビー: https://github.com/sstephenson/global_phone
- C#: https://github.com/twcclegg/libphonenumber-csharp
- 目的-C: https://github.com/iziz/libPhoneNumber-iOS
- JavaScript: https://github.com/ruimarinho/google-libphonenumber
- エリクサー: https://github.com/socialpaymentsbv/ex_phone_number
常に 1 つのロケールからの番号を受け入れ、常に 1 つの形式で番号を受け入れることが確実でない限り、このための独自のコードを作成せず、電話番号の検証と表示に libphonenumber を使用することを強くお勧めします。
/^(?:(?:\(?(?:00|\+)([1-4]\d\d|[1-9]\d?)\)?)?[\-\.\ \\\/]?)?((?:\(?\d{1,}\)?[\-\.\ \\\/]?){0,})(?:[\-\.\ \\\/]?(?:#|ext\.?|extension|x)[\-\.\ \\\/]?(\d+))?$/i
これは以下と一致します:
- (+351) 282 43 50 50
- 90191919908
- 555-8909
- 001 6867684
- 001 6867684x1
- 1 (234) 567-8901
- 1-234-567-8901 x1234
- 1-234-567-8901 ext1234
- 1-234 567.89/01 ext.1234
- 1(234)5678901x1234
- (123)8575973
- (0055)(123)8575973
$n では、次のものが節約されます。
- 国別指標
- 電話番号
- 拡大
でテストできます https://www.regexpal.com/?fam=99127
すべての空白を削除するという答えは適切ですが、正規表現を見つけるという、提起されている問題を実際には解決しません。たとえば、Web ページをダウンロードし、正規表現を使用してすべての電話番号を抽出するテスト スクリプトを考えてみましょう。いずれにせよ正規表現が必要なので、正規表現にすべての作業を実行させたほうがよいでしょう。私はこれを思いつきました:
1?\W*([2-9][0-8][0-9])\W*([2-9][0-9]{2})\W*([0-9]{4})(\se?x?t?(\d*))?
これをテストするための Perl スクリプトを示します。一致すると、$1 には市外局番が含まれ、$2 と $3 には電話番号が含まれ、$5 には内線番号が含まれます。私のテスト スクリプトはインターネットからファイルをダウンロードし、そのファイルに含まれるすべての電話番号を出力します。
#!/usr/bin/perl
my $us_phone_regex =
'1?\W*([2-9][0-8][0-9])\W*([2-9][0-9]{2})\W*([0-9]{4})(\se?x?t?(\d*))?';
my @tests =
(
"1-234-567-8901",
"1-234-567-8901 x1234",
"1-234-567-8901 ext1234",
"1 (234) 567-8901",
"1.234.567.8901",
"1/234/567/8901",
"12345678901",
"not a phone number"
);
foreach my $num (@tests)
{
if( $num =~ m/$us_phone_regex/ )
{
print "match [$1-$2-$3]\n" if not defined $4;
print "match [$1-$2-$3 $5]\n" if defined $4;
}
else
{
print "no match [$num]\n";
}
}
#
# Extract all phone numbers from an arbitrary file.
#
my $external_filename =
'http://web.textfiles.com/ezines/PHREAKSANDGEEKS/PnG-spring05.txt';
my @external_file = `curl $external_filename`;
foreach my $line (@external_file)
{
if( $line =~ m/$us_phone_regex/ )
{
print "match $1 $2 $3\n";
}
}
編集:
正規表現内の \W* を \s*\W?\s* に変更して、少し厳密にすることができます。これを書いたときは、たとえばフォーム上のユーザー入力を検証するという観点から正規表現について考えていませんでしたが、この変更により、その目的で正規表現を使用できるようになりました。
'1?\s*\W?\s*([2-9][0-8][0-9])\s*\W?\s*([2-9][0-9]{2})\s*\W?\s*([0-9]{4})(\se?x?t?(\d*))?';
このスレッドに自分の回答を回答として含めることを決定する前に、別の SO 質問でこの質問に回答しました。これは、アイテムを必須/不要にする方法に誰も対処しておらず、正規表現を配布しているだけだったためです。正規表現が間違って動作し、予期しないものと一致する
そのサイトでの私の投稿から、誰もが自分の希望する電話番号形式に合わせて独自の正規表現を作成できるように支援するためのクイック ガイドを作成しました。ただし、(他のサイトで行ったように) 制限が厳しすぎる場合は、次の点に注意してください。望ましい結果が得られない可能性があります。また、世界中のすべての電話番号を受け入れるための「フリーサイズ」の解決策はありません。選択した形式として受け入れると決めたもののみを受け入れます。自己責任。
クイックチートシート
- 式を開始します。
/^
- スペースが必要な場合は、次を使用します。
[\s]
または\s
- 括弧が必要な場合は、次を使用します。
[(]
そして[)]
。使用する\(
そして\)
は醜く、物事を混乱させる可能性があります。 - 何かをオプションにしたい場合は、
?
その後 - ハイフンが必要な場合は、単に入力してください
-
または[-]
。ただし、これを他の一連の文字の最初または最後に配置しない場合は、エスケープする必要がある場合があります。\-
- スロット内でさまざまな選択肢を受け入れたい場合は、オプションを括弧で囲みます。
[-.\s]
ハイフン、ピリオド、またはスペースが必要です。最後の括弧の後に疑問符を付けると、そのスロットではそれらがすべてオプションになります。 \d{3}
:3 桁の数字が必要です:000-999。の短縮形[0-9][0-9][0-9]
.[2-9]
:そのスロットには 2 ~ 9 の数字が必要です。(\+|1\s)?
:「プラス」または 1 とスペース (パイプ文字、|
, 、は「または」)、オプションにします。「プラス」記号はエスケープする必要があります。- 特定の番号をスロットに一致させたい場合は、それらを入力します。
[246]
2、4、または 6 が必要になります。[77|78]
77 または 78 が必要になります。 $/
:式を終了する
最も単純に書きました(ただし、ドットは必要ありませんでした)。
^([0-9\(\)\/\+ \-]*)$
以下で説明するように、文字だけをチェックし、その構造や順序はチェックしません。
ストリップに注意してください ()
文字は、一般的な英国の数字の書き方では機能しません。 +44 (0) 1234 567890
これは、次のいずれかの国際番号をダイヤルすることを意味します。
+441234567890
または英国のダイヤルで 01234567890
フィールドにランダムなガベージ (つまり、フォームスパマーから) がないことを確認したいだけの場合は、次の正規表現で適切に実行できます。
^[0-9+\(\)#\.\s\/ext-]+$
桁数やその桁で有効な数字について特別なルールはなく、数字、括弧、ダッシュ、プラス、スペース、ポンド、アスタリスク、ピリオド、カンマ、または文字のみが検証されるだけであることに注意してください。 e
, x
, t
存在しています。
国際番号およびローカリゼーション形式と互換性がある必要があります。一部の地域では角括弧、中括弧、または山括弧を許可する必要があると予想されますか?(現在、それらは含まれていません)。
桁ごとのルール (米国の市外局番やプレフィックス (交換コード) は 200 ~ 999 の範囲に収まる必要があるなど) を維持したい場合は、頑張ってください。世界中のどの国でも、将来的に時代遅れになる可能性のある複雑なルールセットを維持することは、楽しいことではありません。
また、数値以外の文字のすべてまたはほとんどを削除することはサーバー側ではうまく機能するかもしれませんが (特にこれらの値をダイヤラーに渡すことを計画している場合)、検証中にユーザーの入力をスラッシングしたくない場合があります。別のフィールドで修正します。
見てみましたか RegExLib?
米国の電話番号を入力すると、さまざまな可能性のリストが表示されました。
制限のない正規表現への私の試み:
/^[+#*\(\)\[\]]*([0-9][ ext+-pw#*\(\)\[\]]*){6,45}$/
受け入れます:
+(01) 123 (456) 789 ext555
123456
*44 123-456-789 [321]
123456
123456789012345678901234567890123456789012345
*****++[](][((( 123456tteexxttppww
拒否:
mob 07777 777777
1234 567 890 after 5pm
john smith
(empty)
1234567890123456789012345678901234567890123456
911
展示用に消毒するかどうかはあなた次第です。検証してから できた ただし数字であってください。
これは非常にうまく機能することがわかりました。
^\(*\+*[1-9]{0,3}\)*-*[1-9]{0,3}[-. /]*\(*[2-9]\d{2}\)*[-. /]*\d{3}[-. /]*\d{4} *e*x*t*\.* *\d{0,4}$
次の数値形式で機能します。
1-234-567-8901
1-234-567-8901 x1234
1-234-567-8901 ext1234
1 (234) 567-8901
1.234.567.8901
1/234/567/8901
12345678901
1-234-567-8901 ext. 1234
(+351) 282 433 5050
確実にグローバル AND 複数行フラグを使用してください。
フォームの検証について話している場合、正しい意味と正しいデータを検証するための正規表現は、国やプロバイダーの標準が異なるため、非常に複雑になります。最新の状態を保つのも大変になります。
私はこの質問を、内部的には一貫していない可能性がある、広く有効なパターンを探していると解釈します。たとえば、有効な番号のセットはあるものの、トランクラインや交換機などであることを検証していないなどです。国番号プレフィックスの有効なパターンに変更します。
北米の場合は単純ですが、国際的な場合は、人々が自分の番号を指定して記憶する方法をカバーする「慣用的な」パターンを使用することを好みます。
^((((\(\d{3}\))|(\d{3}-))\d{3}-\d{4})|(\+?\d{2}((-| )\d{1,8}){1,5}))(( x| ext)\d{1,5}){0,1}$
北米のパターンでは、1 つの括弧が含まれる場合は、両方の括弧が含まれることを確認します。国際は、オプションの最初の「+」と国コードを考慮します。その後は慣用句になります。有効な一致は次のとおりです。
(xxx)xxx-xxxx
(xxx)-xxx-xxxx
(xxx)xxx-xxxx x123
12 1234 123 1 x1111
12 12 12 12 12
12 1 1234 123456 x12345
+12 1234 1234
+12 12 12 1234
+12 1234 5678
+12 12345678
私の経験は北米、ヨーロッパ、そして少しのアジアに限定されているため、これは偏見があるかもしれません。
このトピックに対する多くの返信によって、私の直感はさらに強くなりました。この問題には事実上無限の解決策があり、どれも洗練されたものではないということです。
正直に言って、電話番号を認証しようとしないことをお勧めします。たとえ、さまざまな正当な形式をすべて許可する巨大で毛深いバリデータを作成できたとしても、最終的には、そもそも電話番号に似ているものであっても、ほとんどすべてを許可することになります。
私の意見では、最も洗練された解決策は、最小の長さを検証することであり、それ以上のものではありません。
これは、フィリピンの携帯電話番号の単純な正規表現パターンです。
((\+[0-9]{2})|0)[.\- ]?9[0-9]{2}[.\- ]?[0-9]{3}[.\- ]?[0-9]{4}
または
((\+63)|0)[.\- ]?9[0-9]{2}[.\- ]?[0-9]{3}[.\- ]?[0-9]{4}
これらと一致します:
+63.917.123.4567
+63-917-123-4567
+63 917 123 4567
+639171234567
09171234567
最初のものは任意の 2 桁の国コードと一致しますが、2 つ目はフィリピンの国コードのみと一致します。
ここでテストしてください: http://refiddle.com/1ox
単一の単純な正規表現で国際番号を扱うのは難しいでしょう。を参照してください。 この郵便受け 国際電話番号(さらには北米)の電話番号の難しさについて。
最初の数桁を解析して国コードを特定し、国に応じて異なる動作を行う必要があります。
それ以上に、あなたが指定したリストには、最初の 1 を除いた別の一般的な米国形式が含まれていません。米国のほとんどの携帯電話はこれを必要とせず、国際電話をかけたことがない若い世代は困惑し始めるだろう。
それが難しい問題であることを正しく認識しました...
-アダム
これは、私が達成する必要があった検証に最もよく一致する素晴らしいパターンです。私は元の著者ではありませんが、この問題は非常に複雑で、簡潔で広く役立つ答えがないことがわかったので、共有する価値は十分にあると思います。
次の正規表現は、世界のさまざまな電話番号形式で広く使用されている数字と文字の組み合わせを検出します。
/^\s*(?:\+?(\d{1,3}))?([-. (]*(\d{3})[-. )]*)?((\d{3})[-. ]*(\d{2,4})(?:[-.x ]*(\d+))?)\s*$/gm
ポジティブ:
+42 555.123.4567
+1-(800)-123-4567
+7 555 1234567
+7(926)1234567
(926) 1234567
+79261234567
926 1234567
9261234567
1234567
123-4567
123-89-01
495 1234567
469 123 45 67
89261234567
8 (926) 1234567
926.123.4567
415-555-1234
650-555-2345
(416)555-3456
202 555 4567
4035555678
1 416 555 9292
ネガティブ:
926 3 4
8 800 600-アップル
元のソース: http://www.regexr.com/38pvb
これがこれまでの私の最善の試みです。上記の形式を処理しますが、他の可能な形式が欠けていると思います。
^\d?(?:(?:[\+]?(?:[\d]{1,3}(?:[ ]+|[\-.])))?[(]?(?:[\d]{3})[\-/)]?(?:[ ]+)?)?(?:[a-zA-Z2-9][a-zA-Z0-9 \-.]{6,})(?:(?:[ ]+|[xX]|(i:ext[\.]?)){1,2}(?:[\d]{1,5}))?$
これらの回答を読んだ後、大量のテキストを解析して、あらゆる形式 (プラス記号の有無にかかわらず国際電話番号を含む) で電話番号を取り出すことができる単純な正規表現は存在しなかったようです。
これは私が最近クライアント プロジェクトで使用したものです。このプロジェクトでは、あらゆる形式の電話番号をすべて Tel に変換する必要がありました。リンク。
これまでのところ、彼らが投げたものはすべて機能していますが、エラーが発生した場合は、この回答を更新します。
正規表現:
/(\+*\d{1,})*([ |\(])*(\d{3})[^\d]*(\d{3})[^\d]*(\d{4})/
すべての電話番号を tel に置き換える PHP 関数:リンク (興味がある人のために):
function phoneToTel($number) {
$return = preg_replace('/(\+*\d{1,})*([ |\(])*(\d{3})[^\d]*(\d{3})[^\d]*(\d{4})/', '<a href="tel:$1$3$4$5">$1 ($3) $4-$5</a>', $number); // includes international
return $return;
}
私は信じます 番号::電話番号::米国 そして 正規表現::共通 (特にソース 正規表現::共通::URI::RFC2806) Perl モジュールが役に立つかもしれません。
数値を検証する目的を説明するには、おそらく質問をもう少し詳しく指定する必要があります。たとえば、911 は米国では有効な番号ですが、911x は x のどの値にも使用できません。これは、あなたがダイヤルし終わったときに電話会社が計算できるようにするためです。この問題にはいくつかのバリエーションがあります。ただし、正規表現では市外局番部分はチェックされないため、心配する必要はないようです。
電子メール アドレスの検証と同様、有効な結果が得られたとしても、それが誰かに割り当てられているかどうかは、試してみるまでわかりません。
ユーザー入力を検証しようとしているのであれば、結果を正規化してそれで終わりではどうでしょうか?ユーザーが有効な数値として認識できない数値を入力した場合は、その数値を入力したまま保存するか、使用できない文字を削除してください。の 番号::電話番号::正規化 Perl モジュールがインスピレーションの源になる可能性があります。
私は市場調査会社で働いていますが、常にこの種の入力をフィルタリングする必要があります。複雑にしすぎていますね。英数字以外の文字を削除して、拡張子があるかどうかを確認してください。
さらに分析するには、有効な番号のデータベースにアクセスしたり、電話番号が固定電話か携帯電話か、切断されているかどうかなどを知ることができる多くのプロバイダーの 1 つに登録できます。お金がかかります。
書式設定文字の置換を実行し、残りの文字が電話の有効性を確認します。PHPでは、
$replace = array( ' ', '-', '/', '(', ')', ',', '.' ); //etc; as needed
preg_match( '/1?[0-9]{10}((ext|x)[0-9]{1,4})?/i', str_replace( $replace, '', $phone_num );
このように複雑な正規表現を破ることも同様に効果的ですが、はるかに簡単です。
これは面白いことだと思いました。テストしていませんが、うまくいくようです
<?php
/*
string validate_telephone_number (string $number, array $formats)
*/
function validate_telephone_number($number, $formats)
{
$format = trim(ereg_replace("[0-9]", "#", $number));
return (in_array($format, $formats)) ? true : false;
}
/* Usage Examples */
// List of possible formats: You can add new formats or modify the existing ones
$formats = array('###-###-####', '####-###-###',
'(###) ###-###', '####-####-####',
'##-###-####-####', '####-####', '###-###-###',
'#####-###-###', '##########');
$number = '08008-555-555';
if(validate_telephone_number($number, $formats))
{
echo $number.' is a valid phone number.';
}
echo "<br />";
$number = '123-555-555';
if(validate_telephone_number($number, $formats))
{
echo $number.' is a valid phone number.';
}
echo "<br />";
$number = '1800-1234-5678';
if(validate_telephone_number($number, $formats))
{
echo $number.' is a valid phone number.';
}
echo "<br />";
$number = '(800) 555-123';
if(validate_telephone_number($number, $formats))
{
echo $number.' is a valid phone number.';
}
echo "<br />";
$number = '1234567890';
if(validate_telephone_number($number, $formats))
{
echo $number.' is a valid phone number.';
}
?>
おそらく、これにはマスクされた入力を使用した方がよいでしょう。こうすることで、ユーザーは数値のみを入力でき、必要に応じてフォーマットを設定できます。これが Web アプリケーション用であるかどうかはわかりませんが、Web アプリケーション用である場合は、これを実行するためのいくつかのオプションを提供する非常にクリック的な jQuery プラグインがあります。
http://digitalbush.com/projects/masked-input-plugin/
チュートリアルでは、電話番号入力をマスクする方法についても説明しています。
これは JavaScript でうまく動作するものです。Dojo ウィジェットがそれを予期していたため、これは文字列内にあります。
これは、オプションの内線番号を付けた 10 桁の北米 NANP 番号と一致します。スペース、ダッシュ、ピリオドを区切り文字として使用できます。
"^(\\(?\\d\\d\\d\\)?)( |-|\\.)?\\d\\d\\d( |-|\\.)?\\d{4,4}(( |-|\\.)?[ext\\.]+ ?\\d+)?$"
私も同じ問題に悩まされ、アプリケーションを将来にわたって使えるものにしようとしていましたが、彼らが私を正しい方向に導いてくれました。実際に番号自体が機能するかどうかをチェックしているのではなく、内線番号が付いている場合と付いていない場合がある一連の番号が入力されたかどうかを確認しようとしているだけです。
最悪のシナリオでは、ユーザーが XML ファイルからフォーマットされていない番号を取得する必要がある場合でも、電話機のテンキーに番号を入力するだけになります。 012345678x5
, 、それを美しく保つ本当の理由はありません。その種の正規表現は、私にとっては次のようになります。
\d+ ?\w{0,9} ?\d+
01234467 extension 123456
01234567x123456
01234567890
私の傾向としては、数字以外のものを取り除き、そこにあるものだけを受け入れるのが最善だということに同意します。おそらく、少なくとも数桁の数字が存在することを保証するためでしょう。ただし、たとえば、アルファベットの電話番号「ASK-JAKE」のようなものは禁止されています。
いくつかの単純な Perl 式は次のようになります。
@f = /(\d+)/g;
tr/0-9//dc;
最初のものを使用して数字グループをまとめておきます。これにより書式設定の手がかりが得られる可能性があります。2 番目のものを使用して、数字以外のすべてを簡単に投げます。
一時停止してからさらにキーを入力する必要があるのではないかという心配はありませんか?それとも 555-1212 (ビープ音が鳴るのを待ちます) 123 のようなものですか?
pattern="^[\d|\+|\(]+[\)|\d|\s|-]*[\d]$"
validateat="onsubmit"
数字で終わる必要があり、( または + または数字で始めることができ、+ - ( または ) を含めることができます)
アイルランドの携帯電話番号で同様のことを行うことに興味がある人のために、それを実現する簡単な方法を次に示します。
PHP
<?php
$pattern = "/^(083|086|085|086|087)\d{7}$/";
$phone = "087343266";
if (preg_match($pattern,$phone)) echo "Match";
else echo "Not match";
そのリンクには JQuery ソリューションもあります。
編集:
jQuery ソリューション:
$(function(){
//original field values
var field_values = {
//id : value
'url' : 'url',
'yourname' : 'yourname',
'email' : 'email',
'phone' : 'phone'
};
var url =$("input#url").val();
var yourname =$("input#yourname").val();
var email =$("input#email").val();
var phone =$("input#phone").val();
//inputfocus
$('input#url').inputfocus({ value: field_values['url'] });
$('input#yourname').inputfocus({ value: field_values['yourname'] });
$('input#email').inputfocus({ value: field_values['email'] });
$('input#phone').inputfocus({ value: field_values['phone'] });
//reset progress bar
$('#progress').css('width','0');
$('#progress_text').html('0% Complete');
//first_step
$('form').submit(function(){ return false; });
$('#submit_first').click(function(){
//remove classes
$('#first_step input').removeClass('error').removeClass('valid');
//ckeck if inputs aren't empty
var fields = $('#first_step input[type=text]');
var error = 0;
fields.each(function(){
var value = $(this).val();
if( value.length<12 || value==field_values[$(this).attr('id')] ) {
$(this).addClass('error');
$(this).effect("shake", { times:3 }, 50);
error++;
} else {
$(this).addClass('valid');
}
});
if(!error) {
if( $('#password').val() != $('#cpassword').val() ) {
$('#first_step input[type=password]').each(function(){
$(this).removeClass('valid').addClass('error');
$(this).effect("shake", { times:3 }, 50);
});
return false;
} else {
//update progress bar
$('#progress_text').html('33% Complete');
$('#progress').css('width','113px');
//slide steps
$('#first_step').slideUp();
$('#second_step').slideDown();
}
} else return false;
});
//second section
$('#submit_second').click(function(){
//remove classes
$('#second_step input').removeClass('error').removeClass('valid');
var emailPattern = /^[a-zA-Z0-9._-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,4}$/;
var fields = $('#second_step input[type=text]');
var error = 0;
fields.each(function(){
var value = $(this).val();
if( value.length<1 || value==field_values[$(this).attr('id')] || ( $(this).attr('id')=='email' && !emailPattern.test(value) ) ) {
$(this).addClass('error');
$(this).effect("shake", { times:3 }, 50);
error++;
} else {
$(this).addClass('valid');
}
function validatePhone(phone) {
var a = document.getElementById(phone).value;
var filter = /^[0-9-+]+$/;
if (filter.test(a)) {
return true;
}
else {
return false;
}
}
$('#phone').blur(function(e) {
if (validatePhone('txtPhone')) {
$('#spnPhoneStatus').html('Valid');
$('#spnPhoneStatus').css('color', 'green');
}
else {
$('#spnPhoneStatus').html('Invalid');
$('#spnPhoneStatus').css('color', 'red');
}
});
});
if(!error) {
//update progress bar
$('#progress_text').html('66% Complete');
$('#progress').css('width','226px');
//slide steps
$('#second_step').slideUp();
$('#fourth_step').slideDown();
} else return false;
});
$('#submit_second').click(function(){
//update progress bar
$('#progress_text').html('100% Complete');
$('#progress').css('width','339px');
//prepare the fourth step
var fields = new Array(
$('#url').val(),
$('#yourname').val(),
$('#email').val(),
$('#phone').val()
);
var tr = $('#fourth_step tr');
tr.each(function(){
//alert( fields[$(this).index()] )
$(this).children('td:nth-child(2)').html(fields[$(this).index()]);
});
//slide steps
$('#third_step').slideUp();
$('#fourth_step').slideDown();
});
$('#submit_fourth').click(function(){
url =$("input#url").val();
yourname =$("input#yourname").val();
email =$("input#email").val();
phone =$("input#phone").val();
//send information to server
var dataString = 'url='+ url + '&yourname=' + yourname + '&email=' + email + '&phone=' + phone;
alert (dataString);//return false;
$.ajax({
type: "POST",
url: "http://clients.socialnetworkingsolutions.com/infobox/contact/",
data: "url="+url+"&yourname="+yourname+"&email="+email+'&phone=' + phone,
cache: false,
success: function(data) {
console.log("form submitted");
alert("success");
}
});
return false;
});
//back button
$('.back').click(function(){
var container = $(this).parent('div'),
previous = container.prev();
switch(previous.attr('id')) {
case 'first_step' : $('#progress_text').html('0% Complete');
$('#progress').css('width','0px');
break;
case 'second_step': $('#progress_text').html('33% Complete');
$('#progress').css('width','113px');
break;
case 'third_step' : $('#progress_text').html('66% Complete');
$('#progress').css('width','226px');
break;
default: break;
}
$(container).slideUp();
$(previous).slideDown();
});
});
ソース.