gpt4 book ai didi

c# - 有没有电话号码清理库之类的东西

转载 作者:太空狗 更新时间:2023-10-29 17:47:09 26 4
gpt4 key购买 nike

我想找到一个工具/库,可以将用户通过网站输入的自由格式电话号码解析为适合从特定国家/地区调用电话的号码。

这并不像乍听起来那么简单。该网站允许世界各地的人们以他们选择的任何方式输入他们的号码,因此许多人输入国家号码(在另一个字段中也提供了一个国家)。有些人以“正确”的格式(带有“+”)输入国际号码,有些人使用他们国家/地区的国际前缀输入略微不正确。

我想告诉图书馆/工具我调用电话的国家,以及自由格式的电话号码和可选的国家(如果没有输入,这将有助于生成国际代码),它使用已知模式来最好地猜测在我的调用国家/地区可以使用的号码

因此,例如,当从美国调用英国号码时:

+44 (0) 1225-344567 => 011441225344567

或者从英国调用美国号码时:

(613) 4562342 => 0016134562342

任何人都知道任何(最好是 .NET Framework 友好的)解决方案可以避免我毫无疑问地重新发明轮子

最佳答案

我已经实现了这个,马克。我在一家无线运营商工作,并且有一个国际 SMS 发送应用程序。我不知道有任何第三方图书馆实现这些规则。如上所述,由于电话号码格式因国家/地区而异,因此不能只处理随机输入。德国等一些国家/地区的区号和电话号码长度可变。如果他们不把国家代码放在那里,你就完蛋了。但是,就我而言,如果缺少国家代码,我可以假设它是美国电话号码。事实证明,我的过滤器的结果对于我所拥有的用户和输入非常准确。

可以做一些假设,通过了解目标受众、记录输入和分析,可以拨入内容。我的第一个实现是针对一个“白标”网络应用程序,供不同的人进行测试世界各地。我很快发现大多数外国人都有自己的行为,习惯了准标准+格式。通常美国人在输入电话号码时最容易混淆。欧洲人非常习惯调用国际电话。

第一条规则是去除除数字和前导“+”之外的所有内容。

如果结果数字少于 8 位,则为垃圾,提供用户错误。

如果结果数字以“+”开头,则假定它是标准格式,接下来的 2-6 位数字代表“国家/地区代码”。找出国家代码,然后根据该国家/地区的规则处理剩余的数字。

如果数字以 0 开头,假设有人输入了国际访问前缀,并去掉了前导 0 和 1,那么:如果余下的号码是10位,则认为是美国人输入的美国号码,并作相应处理。如果剩余的数字不是10位,但至少是8位,假设前2-6位是国家代码,查找国家代码,并按照该国家的规则处理。

如果号码以 1 开头,总共 11 位,则假定它是美国(或加勒比海岛屿)号码,并进行相应处理。

如果数字以 1 开头且总共不是 11 位数字,则去除前导 1,查看是否至少还剩下 8 位数字,并假设剩余的前导 2 到 6 位数字是国家代码并按国家/地区处理规则。

最后,数字不以+、0、1开头,且至少为8位,假设是不带+的标准表示法,即国家代码在前,取前2-6位为国家代码并根据该国家的规则进行处理。

所有这一切的诀窍是拥有世界上所有国家代码的映射,以及每个国家的编号计划信息。我有那张 map ,还有很多国家的规定。如果您想要此信息,我很乐意与您分享,以及一些确定哪个国家/地区的 C# 代码。给我留言。

这方面的一个巨大帮助是将您的软件猜测的国家/地区的名称发回给用户。如果他们尝试输入德国电话号码并且您的软件会询问他们是否尝试调用关岛,他们会很快理解!

关于c# - 有没有电话号码清理库之类的东西,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6493922/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com