我想为一个标准的美国类型的电话号码,支持以下格式写一个正则表达式:

###-###-####
(###) ###-####
### ### ####
###.###.####

其中#表示任意数字。到目前为止,我想出了以下表达方式

^[1-9]\d{2}-\d{3}-\d{4}
^\(\d{3}\)\s\d{3}-\d{4}
^[1-9]\d{2}\s\d{3}\s\d{4}
^[1-9]\d{2}\.\d{3}\.\d{4}

分别。我不太确定最后一条是否正确。我还想知道是否有任何方式,我可以写一个单一的表达式,而不是4个不同的迎合我提到的不同格式。如果是这样,我不知道该怎么做。以及我如何修改表达式/表达式,以便我也可以包括一个条件,以支持区号作为可选组件。类似的

+1 ### ### ####

其中+1是区号,是可选的。


当前回答

^(\+1)?\s?(\([1-9]\d{2}\)|[1-9]\d{2})(-|\s|.)\d{3}(-|\s|.)\d{4}

其他回答

这个问题有很多可能的变化。这是一个正则表达式,类似于我之前放在SO上的答案。

^\s*(?:\+?(\d{1,3}))?[-. (]*(\d{3})[-. )]*(\d{3})[-. ]*(\d{4})(?: *x(\d+))?\s*$

它将匹配以下示例和更多:

18005551234
1 800 555 1234
+1 800 555-1234
+86 800 555 1234
1-800-555-1234
1 (800) 555-1234
(800)555-1234
(800) 555-1234
(800)5551234
800-555-1234
800.555.1234
800 555 1234x5678
8005551234 x5678
1    800    555-1234
1----800----555-1234

无论电话号码的输入方式如何,都可以使用捕获组来分解电话号码,以便在代码中处理它。

第一组:国家代码(例如:1或86) 第二组:地区号码(例如:800) 分组3:Exchange(例如:555) 组四:用户号码(例如:1234) 组5:分机(例如:5678)

如果你感兴趣的话,下面是这个表达的分类:

^\s*                #Line start, match any whitespaces at the beginning if any.
(?:\+?(\d{1,3}))?   #GROUP 1: The country code. Optional.
[-. (]*             #Allow certain non numeric characters that may appear between the Country Code and the Area Code.
(\d{3})             #GROUP 2: The Area Code. Required.
[-. )]*             #Allow certain non numeric characters that may appear between the Area Code and the Exchange number.
(\d{3})             #GROUP 3: The Exchange number. Required.
[-. ]*              #Allow certain non numeric characters that may appear between the Exchange number and the Subscriber number.
(\d{4})             #Group 4: The Subscriber Number. Required.
(?: *x(\d+))?       #Group 5: The Extension number. Optional.
\s*$                #Match any ending whitespaces if any and the end of string.

要使区号可选,只需在区号(\d{3})后面添加一个问号。

这个怎么样?

^(\+?[01])?[-.\s]?\(?[1-9]\d{2}\)?[-.\s]?\d{3}[-.\s]?\d{4}

编辑:我忘记了()。 编辑2:把前三位数字弄错了。

1、3和4的表达式非常相似,所以你可以使用:

^([1-9]\d{2})([- .])(\d{3})$2(\d{4})$

请注意,根据所使用的正则表达式的语言和品牌,您可能需要输入\2而不是$2,否则这种匹配可能根本不受支持。

我认为没有好办法将其与格式2结合起来,除了明显的^(regex for 1,3,4|regex for 2)$,这是丑陋的,笨拙的,并且很难取出数字的部分。

关于区号,你可以加(\+\d)?到开头捕捉一个个位数的区号(对不起,我不知道你区号的格式)。

这是我创建的一个相当紧凑的模型。

Search: \+?1?\s*\(?-*\.*(\d{3})\)?\.*-*\s*(\d{3})\.*-*\s*(\d{4})$

Replace: +1 \($1\) $2-$3

根据以下用例进行测试。

18001234567
1 800 123 4567
1-800-123-4567
+18001234567
+1 800 123 4567
+1 (800) 123 4567
1(800)1234567
+1800 1234567
1.8001234567
1.800.123.4567
1--800--123--4567
+1 (800) 123-4567

用“+”分隔多个数字,然后用“;”"," -"或" "字符?