我正在尝试构建一个正则表达式,它将检查一个字符串是否有0次或1次连字符。
因此,它将返回以下字符串作为ok。
1-5
1,3-5
1,3下面的内容可能是错误的。
1-3-5我已经尝试过以下方法,但1-3-5也没问题:
([^-]?-){0,1}[^-]发布于 2013-06-18 01:13:46
这是可行的:
^[^-]*-?[^-]*$
^^ ^ ^ ^
|| | | |
|| | | |-- Match the end of string
|| | |------- Match zero or more non-hyphen characters
|| |--------- Match zero or one hyphens
||-------------- Match zero or more non-hyphen characters
|--------------- Match the beginning of string在这种情况下,需要指定匹配输入字符串的开头(^)和结尾($),这样就不会对1-3-5这样的字符串进行多次匹配。
发布于 2013-06-18 01:14:13
也许是更简单的东西:
var hyphens = input.Count(cc => cc == '-');您的正则表达式之所以有效,是因为它找到了符合条件的第一个连字符实例。您可以使用以下正则表达式,但它并不理想:
^[^-]*-?[^-]*$发布于 2013-06-18 01:14:36
如果您的字符串在集合中,则可以在LINQ的一行中完成此操作。它将返回一个少于两个连字符的字符串列表。
var okStrings = allStrings.Where(s => s.Count(h => h == '-') < 2).ToList();从您格式化字符串列表的方式来看,我假设您不能在逗号上拆分,因为它不是一致的分隔符。如果可以,您可以只使用String.Split方法来获取每个字符串,并将上面的allStrings变量替换为该数组。
https://stackoverflow.com/questions/17153032
复制相似问题