我想为一个标准的美国类型的电话号码,支持以下格式写一个正则表达式:
###-###-####
(###) ###-####
### ### ####
###.###.####
其中#表示任意数字。到目前为止,我想出了以下表达方式
^[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是区号,是可选的。
我知道这不能直接回答OP的问题,但如果您问的是与OP相同的问题,那么很有可能您正在寻找一种方法来验证和存储电话号码在状态或数据库中。与其试图检测每个可能是电话号码的字符组合,不如将此任务分解为多个步骤。
去掉所有的无数字
去掉前导1s
请确保号码不超过10位
Javascript伪例子,假设"phone"是用户输入存储为字符串:
phone.replace(/\D/g, "")
phone.replace(/^1+/g, "")
phone.slice(0, 10)
phone.length === 10 ? "do something" : "don't do something"
上面的代码将需要根据您的目的进行调整,并为非javascript读者保留尽可能简单的代码。
为了表示的目的,你可以总是层破折号和领先的1,但为了存储,你应该只保留实际的数字。这种方法还有一个额外的优点,就是留给您一些易于理解的正则表达式。
^(\+\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}$
1、3和4的表达式非常相似,所以你可以使用:
^([1-9]\d{2})([- .])(\d{3})$2(\d{4})$
请注意,根据所使用的正则表达式的语言和品牌,您可能需要输入\2而不是$2,否则这种匹配可能根本不受支持。
我认为没有好办法将其与格式2结合起来,除了明显的^(regex for 1,3,4|regex for 2)$,这是丑陋的,笨拙的,并且很难取出数字的部分。
关于区号,你可以加(\+\d)?到开头捕捉一个个位数的区号(对不起,我不知道你区号的格式)。