我想为一个标准的美国类型的电话号码,支持以下格式写一个正则表达式:
###-###-####
(###) ###-####
### ### ####
###.###.####
其中#表示任意数字。到目前为止,我想出了以下表达方式
^[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、3和4的表达式非常相似,所以你可以使用:
^([1-9]\d{2})([- .])(\d{3})$2(\d{4})$
请注意,根据所使用的正则表达式的语言和品牌,您可能需要输入\2而不是$2,否则这种匹配可能根本不受支持。
我认为没有好办法将其与格式2结合起来,除了明显的^(regex for 1,3,4|regex for 2)$,这是丑陋的,笨拙的,并且很难取出数字的部分。
关于区号,你可以加(\+\d)?到开头捕捉一个个位数的区号(对不起,我不知道你区号的格式)。
^(\+\d{1,2}\s)?\(?\d{3}\)?[\s.-]\d{3}[\s.-]\d{4}$
匹配以下内容
123-456-7890
(123) 456-7890
123 456 7890
123.456.7890
+91 (123) 456-7890
如果你不想匹配非美国号码使用
^(\+0?1\s)?\(?\d{3}\)?[\s.-]\d{3}[\s.-]\d{4}$
更新:
正如下面用户Simon Weaver所注意到的,如果你也对未格式化的数字感兴趣,只需将分隔符类设置为可选的[\s.-]?
^(\+\d{1,2}\s)?\(?\d{3}\)?[\s.-]?\d{3}[\s.-]?\d{4}$