正则表达式:识别不同格式的电话号码

问题描述 投票:0回答:2

我有一个人们在那里写笑话的网站。用户可以将他们喜欢的笑话作为短信发送给他们(或他们的朋友)的手机。和下面显示的笑话的发送者(谁将笑话添加到网站): 笑话#12234 这是身体 这个笑话 发件人:约翰 有时人们使用他们的电话号码作为发件人姓名,这在公共场合是不允许的。我想确定发件人姓名中是否有电话号码可以审查它。我假设任何大于6位的数字作为电话号码。但问题是用户可能会将数字分开,如:

1234567890应该变成1234XXX7890 123 456 7890应成为123 XXX 7890 123-456-7890 123456-7890

等等。任何与上述格式相似的表格都应予以审查。我尝试删除非数字字符然后使用正则表达式,但问题是它还提取: john23 peterson12345

谁能提供更好的方式?

c# regex
2个回答
0
投票

要保留所有格式,请替换

(\d{3}[-\s()]*)\d{3}([-\s()]*\d{4})

$1XXX$2

要进一步约束10位数字(即不允许紧接前后的其他数字),请使用否定的外观断言:

(?<!\d)(\d{3}[-\s()]*)\d{3}([-\s()]*\d{4})(?!\d)
^^^^^^^                                   ^^^^^^

最后,如果拼写错误导致用户在组之间插入空格或符号,例如(123)45 6-7890?要抓住这些,请执行以下操作:

(?<!\d)((?:\d[-\s()]*){3})(?:\d[-\s()]*){3}((?:\d[-\s()]*){4})(?!\d)

然而,这可能会“过多”,例如1-2-3-4-5-6-7-8-9-0。您必须确定要敲击的余额。


0
投票

由于这个世界上有很多电话号码格式,你可以使用这个正则表达式来识别任何电话号码。 ^[0-9-+s()]*$

© www.soinside.com 2019 - 2024. All rights reserved.