我正在寻找一种优雅的方式,最好是一个简短的 linq 表达式,来计算给定字符串包含多少个字母数字字符。
我现在做的“无聊”方式是这样的:
int num = 0;
for (int i = 0; i < password.Length; i++)
{
if (!char.IsLetterOrDigit(password, i))
{
num++;
}
}
if (num < MinRequiredNonAlphanumericCharacters)
return false;
这已经很短了,但我相信通过一些 linq 魔法,这可以用更短、同样易于理解的表达式来完成,对吧?
最佳答案
这是获取字母和数字计数的快速而肮脏的 LINQ 方法:
password.Count(char.IsLetterOrDigit)
这更像是您正在做的事情的直接副本:
password.Count(c => !char.IsLetterOrDigit(c))
关于c# - 计算字符串中字母数字字符的优雅方法?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11569951/