我需要编写一个正则表达式来获取这样的输入
23,456,22,1,32767
即。
目前我使用的是正则表达式[0-9]+(,[0-9]+)*
。
这允许数字仅用逗号分隔(根本不允许空格),并且不检查数字范围。
答案 0 :(得分:16)
分两步完成它可能是明智之举。首先检查范围是0-99999:
^[0-9]{1,5}( *, *[0-9]{1,5})*$
然后使用通用编程语言将字符串解析为整数列表,并检查每个整数x的x <= 32767
。
答案 1 :(得分:9)
你可以使用正则表达式验证数字范围,但是由于你需要查看数字的文本表示,正则表达式很难阅读:
0*(?:3276[0-7]|327[0-5][0-9]|32[0-6][0-9]{2}|3[01][0-9]{3}|[12][0-9]{4}|[1-9][0-9]{1,3}|[0-9])
匹配0到32767之间的整数,带有可选的前导零。
所以你的整个正则表达式都是
^0*(?:3276[0-7]|327[0-5][0-9]|32[0-6][0-9]{2}|3[01][0-9]{3}|[12][0-9]{4}|[1-9][0-9]{1,3}|[0-9])(?: *, *0*(?:3276[0-7]|327[0-5][0-9]|32[0-6][0-9]{2}|3[01][0-9]{3}|[12][0-9]{4}|[1-9][0-9]{1,3}|[0-9]))*$
现在假设你从几年前离开公司的同事那里继承了那个正则表达式......玩得开心:)
因此,请听Mark的建议。
这个答案纯粹是出于教育目的,不构成了在这种情况下使用正则表达式的建议。