我有一个很长的方法,像这样,对每个字符都进行了硬编码。有没有办法使用Regex
这样的东西,使它更短,并且更容易 ?
private static bool IsValid(char character)
{
return new List<char>(new[]
{
'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l',
'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x',
'y', 'z', '1', '2', '3', '4', '5', '6', '7', '8', '9', '0', '-', '.'
}).Contains(character);
}
答案 0 :(得分:4)
我建议检查范围,例如
private static bool IsValid(char character) {
return character >= 'a' && character <= 'z' || // letters
character >= '0' && character <= '9' || // digits
character == '-' || // special characters
character == '.';
}
从技术上讲,您可以使用正则表达式,但这是过冲:
private static bool IsValid(char character) {
return Regex.IsMatch(character.ToString(), @"[a-z0-9\.\-]");
}