繁体   English   中英

替换所有非ASCII字符,C#中的直角字符除外

[英]Replacing all non-ASCII characters, except right angle character in C#

编写文件实用程序以从文件中去除所有非ASCII字符。 我有这个正则表达式:

Regex rgx = new Regex(@"[^\u0000-\u007F]");

哪个工作正常。 但不幸的是,我发现一些愚蠢的人使用直角(¬)作为文件中的分隔符,所以这些也被剥离了,但我需要那些!

我是Regex的新手,我确实了解基础知识,但任何帮助都会很棒!

提前致谢!

您只需要在集合中包含尖括号的代码点:

尝试这个:

Regex rgx = new Regex(@"[^\uxxxx\u0000-\u007F]");

或这个:

Regex rgx = new Regex(@"[^\uxxxx-\uxxxx\u0000-\u007F]");

(其中xxxx是要保留的字符的Unicode代码点。)

这里给出两个选项的原因是我知道你可以在一个负字符组中指定多个范围,但我不知道你是否可以匹配具有范围的单个字符。

乔恩的回答绝对正确。 您可能正在为该角色使用错误的代码。 对于外观相似的字符,请尝试以下操作:

Regex regex = new Regex(@"([^\u00ac\u0000-\u007F])");
Regex regex = new Regex(@"([^\u02fa\u0000-\u007F])");
Regex regex = new Regex(@"([^\u031a\u0000-\u007F])");

我认为第一个应该工作。

暂无
暂无

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

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