用空字符串替换非数字

Mat*_*wdy 123 c# regex string phone-number

在我们的项目中快速添加需求.我们的数据库中用于保存电话号码的字段设置为仅允许10个字符.所以,如果我通过"(913)-444-5555"或其他任何东西,是否有一种快速的方法来通过某种特殊的替换函数运行字符串,我可以传递一组字符允许?

正则表达式?

Joe*_*orn 244

绝对是正则表达式:

string CleanPhone(string phone)
{
    Regex digitsOnly = new Regex(@"[^\d]");   
    return digitsOnly.Replace(phone, "");
}
Run Code Online (Sandbox Code Playgroud)

或者在一个类中,以避免一直重新创建正则表达式:

private static Regex digitsOnly = new Regex(@"[^\d]");   

public static string CleanPhone(string phone)
{
    return digitsOnly.Replace(phone, "");
}
Run Code Online (Sandbox Code Playgroud)

根据您的实际输入,您可能需要一些额外的逻辑来执行诸如去除前导1(用于长距离)或任何尾随x或X(用于扩展)的操作.

  • 注意`[^\d]`可以简化为`\ D` (13认同)

CMS*_*CMS 71

您可以使用正则表达式轻松完成:

string subject = "(913)-444-5555";
string result = Regex.Replace(subject, "[^0-9]", ""); // result = "9134445555"
Run Code Online (Sandbox Code Playgroud)

  • 赞成是一个很好的答案,但乔尔打败了你.谢谢你的答案 - 我真的很想看到来自多个来源的确认. (2认同)

Usm*_*far 38

您不需要使用Regex.

phone = new String(phone.Where(c => char.IsDigit(c)).ToArray())
Run Code Online (Sandbox Code Playgroud)

  • 很好的答案,为什么添加更多对RegularExpressions命名空间的引用 (3认同)
  • 向@Max-PC 的 LINQ 解决方案基准代码添加测试结果 -- StringBuilder: 273ms, Regex: 2096ms, LINQ: 658ms。比 StringBuilder 慢,但仍然比 Regex 快得多。鉴于这是对 1,000,000 次替换进行基准测试,对于大多数场景,StringBuilder 和 LINQ 解决方案之间的有效差异可能可以忽略不计。 (3认同)

Aar*_*ron 23

这是扩展方法的方法.

public static class Extensions
{
    public static string ToDigitsOnly(this string input)
    {
        Regex digitsOnly = new Regex(@"[^\d]");
        return digitsOnly.Replace(input, "");
    }
}
Run Code Online (Sandbox Code Playgroud)


Wes*_*son 8

使用.NET中的Regex方法,您应该能够使用\ D匹配任何非数字数字,如下所示:

phoneNumber  = Regex.Replace(phoneNumber, "\D", "");
Run Code Online (Sandbox Code Playgroud)

  • 这不太对.你需要一个@或"\\ D"来逃避正则表达式中的\.此外,您应该使用String.Empty而不是"" (5认同)

Mic*_*ang 5

不使用正则表达式的扩展方法怎么样。

如果您确实坚持使用正则表达式选项之一,请至少RegexOptions.Compiled在静态变量中使用。

public static string ToDigitsOnly(this string input)
{
    return new String(input.Where(char.IsDigit).ToArray());
}
Run Code Online (Sandbox Code Playgroud)

这建立在Usman Zafar的答案转换为方法组的基础上。