我有一个包含数字和分隔符的字符串。
数字可以用逗号
或连字符
分隔。但可能永远不会有两个数字都由连字符分隔且中间没有逗号。
例子:
有效:123,12,2,1-3,1,1-3,1
无效:123,12,2,1-3,1,1-3-5,1
我有一个几乎可以工作的正则表达式,只是它没有检测到那些 1-3-5
无效行。
我怎样才能改进以下内容?
^([0-9])+((,|-)[0-9]+)*$
最佳答案
你可以分解你的输入:
- 正常:一位或多位数字,可选地后跟破折号,然后是一位或多位数字;
- 特殊:逗号。
正常情况下的正则表达式可以写成\d+(?:-\d+)?
;对于特殊情况,这只是 ,
。
应用normal* (special normal*)*
模式,并添加 anchor 和量词,我们有:
^\d+(?:-\d+)?(,\d+(?:-\d+)?)*$
关于java - 如何使用正则表达式验证破折号分隔值?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26676101/