你好,这段代码是由Chris编写的,结合到MackieChan解决方案中
看着代码,我非常迷茫,我想不出如何增加一个范围。
我的意思是这样:
我试着从页面的逗号检测中修改或更新代码,
下面的代码显示了如何使用逗号输入页面,
样本: 1,2,5,3,8,它不接受0,或大于最大页数
我想要的是添加这样的代码:
2-5,8,9或8,9,2-5,意思是,打印的页数是2,3,4,5,8,9
或2,4-6,9,8也就是说,印刷的页数是2,4,5,6,8,9
private rgxNumberWithComma As New System.Text.RegularExpressions.Regex("^([0-9]+,?)+$")
Public Function CheckInput(ByVal valyo As String, _
ByVal origMaxPage As Integer) As Boolean
Dim match = rgxNumberWithComma.Match(valyo)
If Not match.Success Then
Return False
Else
Dim numbers as new List(Of Integer) ‘will store added numbers
For Each Item In valyo.Split(","c)
Dim intValue As Integer
‘Check if number is a valid integer
‘Check if number is 0
‘Check if number has already added the number list
‘Check if number is greater that MaxPage
If Not Integer.TryParse(Item, intValue) _
OrElse intValue > origMaxPage _
OrElse intValue = 0 _
OrElse numbers.Contains(IntValue) Then
Return False
Else
‘Item is valid, continue
Numbers.Add(intValue)
End If
Next
End If
Return True
End Function发布于 2013-07-12 15:34:51
您可以使用它来验证字符串:
^[0-9]+(-[0-9]+)?(,[0-9]+(-[0-9]+)?)+$这还将确保字符串不会以逗号开头或结尾。
为了评估字符串,我建议如下:
Dim numbers as new List(Of Integer) ‘will store added numbers
For Each Item In valyo.Split(","c)
Dim parts = Item.Split("-"c)
If parts.Length > 1 Then
‘Evaluate range
Dim minValue As Integer
Dim maxValue As Integer
If Not Integer.TryParse(Item, minValue) _
OrElse Not Integer.TryParse(Item, maxValue) _
OrElse minValue > maxValue _
OrElse maxValue > origMaxPage _
OrElse minValue = 0 Then
Return False
Else
For value As Integer = minValue To maxValue
If numbers.Contains(value) Then
Return False
End If
‘Item is valid, continue
numbers.Add(value)
Next
End If
Else
Dim intValue As Integer
If Not Integer.TryParse(Item, intValue) _
OrElse intValue > origMaxPage _
OrElse intValue = 0 _
OrElse numbers.Contains(IntValue) Then
Return False
Else
‘Item is valid, continue
numbers.Add(intValue)
End If
End If
Nexthttps://stackoverflow.com/questions/17618412
复制相似问题