你怎么可以从一个字符串剥离非ASCII字符? (在C#)(How can you strip n

2019-06-18 01:26发布

你怎么可以从一个字符串剥离非ASCII字符? (在C#)

Answer 1:

string s = "søme string";
s = Regex.Replace(s, @"[^\u0000-\u007F]+", string.Empty);


Answer 2:

这里是不使用正则表达式纯.NET解决方案:

string inputString = "Räksmörgås";
string asAscii = Encoding.ASCII.GetString(
    Encoding.Convert(
        Encoding.UTF8,
        Encoding.GetEncoding(
            Encoding.ASCII.EncodingName,
            new EncoderReplacementFallback(string.Empty),
            new DecoderExceptionFallback()
            ),
        Encoding.UTF8.GetBytes(inputString)
    )
);

它可能看起来繁琐,但它应该是直观的。 它使用.NET ASCII编码字符串转换。 UTF8是在转换过程中使用,因为它可以表示任何原始的字符。 它使用EncoderReplacementFallback向任何非ASCII字符转换为空字符串。



Answer 3:

我相信MonsCamus的意思是:

parsememo = Regex.Replace(parsememo, @"[^\u0020-\u007E]", string.Empty);


Answer 4:

如果你想不剥离,但实际转化拉丁重音的非重音字符,来看看这个问题: 我如何8位字符转换成7位字符? (即Ü到U)



Answer 5:

灵感来自philcruz的正则表达式的解决方案 ,我做了一个纯粹的LINQ解决方案

public static string PureAscii(this string source, char nil = ' ')
{
    var min = '\u0000';
    var max = '\u007F';
    return source.Select(c => c < min ? nil : c > max ? nil : c).ToText();
}

public static string ToText(this IEnumerable<char> source)
{
    var buffer = new StringBuilder();
    foreach (var c in source)
        buffer.Append(c);
    return buffer.ToString();
}

这是未经测试的代码。



Answer 6:

无需正则表达式。 只是使用的编码...

sOutput = System.Text.Encoding.ASCII.GetString(System.Text.Encoding.ASCII.GetBytes(sInput));


Answer 7:

我发现解析注释块从数据库中有用以下稍有改动的范围,这意味着你不会有标签抗衡和逃避,这将导致一个CSV领域成为冷门人物。

parsememo = Regex.Replace(parsememo, @"[^\u001F-\u007F]", string.Empty);

如果你想避免其它特殊字符或特定标点符号检查ASCII表



Answer 8:

这不是最佳的性能,明智的,但一个非常直接的LINQ的方法:

string strippedString = new string(
    yourString.Where(c => c <= sbyte.MaxValue).ToArray()
    );

的缺点是,所有的“存活”字符被首次投入类型的数组char[]然后将其扔掉后的string构造不再使用它。



Answer 9:

我来到这里寻找扩展ASCII字符的解决方案,但无法找到它。 我发现的最接近的是bzlm的解决方案 。 但是,这仅适用于ASCII码127高达(很明显,你可以在自己的代码替换编码类型,但我认为这是一个有点复杂,难于理解。因此,共享这个版本)。 下面是对工作的解决方案,即高达255扩展ASCII码这是ISO 8859-1

它发现和剔除非ASCII字符(大于255)

Dim str1 as String= "â, ??î or ôu              
                            
标签: c# ascii