Ama*_*osh 823
替换[^a-zA-Z0-9 -]
为空字符串.
Regex rgx = new Regex("[^a-zA-Z0-9 -]");
str = rgx.Replace(str, "");
Run Code Online (Sandbox Code Playgroud)
ata*_*ata 341
我可以使用RegEx,它们可以提供优雅的解决方案,但它们可能会导致性能问题.这是一个解决方案
char[] arr = str.ToCharArray();
arr = Array.FindAll<char>(arr, (c => (char.IsLetterOrDigit(c)
|| char.IsWhiteSpace(c)
|| c == '-')));
str = new string(arr);
Run Code Online (Sandbox Code Playgroud)
使用紧凑框架(没有FindAll)时
将FindAll替换为1
char[] arr = str.Where(c => (char.IsLetterOrDigit(c) ||
char.IsWhiteSpace(c) ||
c == '-')).ToArray();
str = new string(arr);
Run Code Online (Sandbox Code Playgroud)
jos*_*989 43
你可以试试:
string s1= Regex.Replace(s,"[^A-Za-z0-9 _]","");
Run Code Online (Sandbox Code Playgroud)
s
你的字符串在哪里
Zai*_*Ali 37
使用System.Linq
string withOutSpecialCharacters = new string(stringWithSpecialCharacters.Where(c =>char.IsLetterOrDigit(c) || char.IsWhiteSpace(c) || c == '-').ToArray());
Run Code Online (Sandbox Code Playgroud)
Tru*_*oft 20
正则表达式是[^\w\s\-]*
:
\s
最好使用而不是space(),因为文本中可能有一个选项卡.
Ppp*_*Ppp 13
根据这个问题的答案,我创建了一个静态类并添加了这些.认为它可能对某些人有用.
public static class RegexConvert
{
public static string ToAlphaNumericOnly(this string input)
{
Regex rgx = new Regex("[^a-zA-Z0-9]");
return rgx.Replace(input, "");
}
public static string ToAlphaOnly(this string input)
{
Regex rgx = new Regex("[^a-zA-Z]");
return rgx.Replace(input, "");
}
public static string ToNumericOnly(this string input)
{
Regex rgx = new Regex("[^0-9]");
return rgx.Replace(input, "");
}
}
Run Code Online (Sandbox Code Playgroud)
然后这些方法可以用作:
string example = "asdf1234!@#$";
string alphanumeric = example.ToAlphaNumericOnly();
string alpha = example.ToAlphaOnly();
string numeric = example.ToNumericOnly();
Run Code Online (Sandbox Code Playgroud)
小智 5
要快点吗?
public static class StringExtensions
{
public static string ToAlphaNumeric(this string self, params char[] allowedCharacters)
{
return new string(Array.FindAll(self.ToCharArray(), c => char.IsLetterOrDigit(c) || allowedCharacters.Contains(c)));
}
}
Run Code Online (Sandbox Code Playgroud)
这将允许您指定要允许的字符。
这是一个非正则表达式堆分配友好的快速解决方案,这正是我正在寻找的。
不安全版。
public static unsafe void ToAlphaNumeric(ref string input)
{
fixed (char* p = input)
{
int offset = 0;
for (int i = 0; i < input.Length; i++)
{
if (char.IsLetterOrDigit(p[i]))
{
p[offset] = input[i];
offset++;
}
}
((int*)p)[-1] = offset; // Changes the length of the string
p[offset] = '\0';
}
}
Run Code Online (Sandbox Code Playgroud)
对于那些不想使用不安全或不信任字符串长度黑客的人。
public static string ToAlphaNumeric(string input)
{
int j = 0;
char[] newCharArr = new char[input.Length];
for (int i = 0; i < input.Length; i++)
{
if (char.IsLetterOrDigit(input[i]))
{
newCharArr[j] = input[i];
j++;
}
}
Array.Resize(ref newCharArr, j);
return new string(newCharArr);
}
Run Code Online (Sandbox Code Playgroud)