本文介绍了检查字符串是否为祸不单行号码的有效表示形式的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我对regex
完全是新手。
我的目标是检查字符串是否为祸不单行数字的有效表示形式。
目前我的实现(我发现效率非常低)是一个包含所有祸不单行数字(0-9,A-F)的列表,并检查我的字符串是否包含给定列表中未包含的字符。
我打赌使用正则表达式很容易做到这一点,但我不知道如何实现它。
private bool ISValidHEX(string s)
{
List<string> ToCheck = new List<string>();
for (int i = 0; i < 10; i++)
{
ToCheck.Add(i.ToString());
}
ToCheck.Add("A");
ToCheck.Add("B");
ToCheck.Add("C");
ToCheck.Add("D");
ToCheck.Add("E");
ToCheck.Add("F");
for (int i = 0; i < s.Length; i++)
{
if( !ToCheck.Contains(s.Substring(i,1)))
{
return false;
}
}
return true;
}
推荐答案
我认为尝试将字符串转换为整数类型并处理任何异常是最快的。使用如下代码:
int num = Int32.Parse(s, System.Globalization.NumberStyles.HexNumber);
生成的代码可能比正则表达式更容易理解,如果您需要解析的值,则特别有用(否则您可以使用Int32.TryParse
,它在其他答案中有充分的说明)。
(我最喜欢的一句话是Jamie Zawinski说的:"有些人在遇到问题时会认为‘我知道,我会用正则表达式。’现在他们有两个问题。")
这篇关于检查字符串是否为祸不单行号码的有效表示形式的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!