繁体   English   中英

如何从字符串中删除特殊字符?

[英]how to remove special character from string?

我目前的情况是,我有一个像“XYZName”这样的字符串,但它应该只需要前 3 个字符,并且在这 3 个字符中不应该有任何特殊字符。

示例:“XYZName”结果应为:XYZ

另一个要求是示例:“X.YZName”或“XY-ZName”结果应该是:XYZ

第一个示例已完成但无法实现第二个示例。 我的代码是

 comName = (comName .Replace(".", string.Empty).Length >= 3
                    ? comName .Replace(" ", string.Empty).Substring(0, 3)
                    : comName .Replace(" ", string.Empty)).ToUpper();

这该怎么做 ?? 提前致谢

评论后更新也允许数字

comName = Regex.Replace(comName, @"[^a-zA-Z\d]", "").Substring(0, 3);

正则表达式使用否定集,因此除azAZ或数字 ( \\d ) 之外的任何字符都将被删除。

删除字符后, Substring取前 3 个。


如果您使用的是 C#8+,您可以用范围替换Substring

comName = Regex.Replace(comName, @"[^a-zA-Z\d]", "")[..3];

您可以确保首先将字符 AZ 与 AZ 以外的可选字符或中间的空白字符匹配 3 次:

^[A-Z][^\sA-Z]*[A-Z][^\sA-Z]*[A-Z]

查看匹配的正则表达式演示

然后从这些匹配项中,删除 AZ 以外的所有字符:

var regex = new Regex(@"^[A-Z][^\sA-Z]*[A-Z][^\sA-Z]*[A-Z]");
string[] strings = {"XYZName", "X.YZName", "XY-ZName"};

foreach (String s in strings)
{
    var m = regex.Match(s);
    if (m.Success) {
        Console.WriteLine(Regex.Replace(m.Value, @"[^A-Z]+", ""));
    }
}

输出

XYZ
XYZ
XYZ

请参阅C# 演示


或者您可以使用 3 个捕获组并直接打印组的值。

^([A-Z])[^\sA-Z]*([A-Z])[^\sA-Z]*([A-Z])

C# 演示| 正则表达式演示

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM