我有一个字符串,可以是逗号分隔的\w
列表,例如:
我试图找到一个JavaScript regexp,它将返回['abc123']
(第一个案例)或['abc123', 'def456', 'ghi789']
(没有逗号)。
我试过了:
^(\w+,?)+$
- 不,因为只有最后一个重复模式匹配,789^(?:(\w+),?)+$
- 同样的故事。我正在使用非捕获支架。然而,重复的单词似乎没有发生捕获我正在尝试用regexp做什么?我尝试了几乎所有分组的组合,使用捕获和非捕获括号,但仍未设法实现这一点......
如果你想在出现问题时丢弃整个输入,最简单的方法是验证,然后拆分:
if (/^\w+(,\w+)*$/.test(input)) {
var values = input.split(',');
// Process the values here
}
如果要允许空值,请将\w+
更改为\w*
。
尝试使用单个正则表达式同时匹配和验证需要模拟\G
功能,该功能断言最后一个匹配的位置。为什么需要\G
?因为它会阻止引擎在下一个位置重试匹配并绕过验证。请记住,ECMA脚本正则表达式没有后视,因此您无法区分无效字符的位置和后面的字符:
something,=bad,orisit,cor&rupt
^^ ^^
如果无法区分这两个位置,则不能仅依赖引擎来进行全匹配操作。虽然可以使用RegExp.exec
的while循环并自己断言最后一次匹配的位置,但为什么在有更清洁的选项时会这样做呢?
如果你想野蛮任何可用的东西,torazaburo's answer是一个可行的选择。
先在逗号上拆分,然后过滤掉不匹配的结果:
str.split(',').filter(function(s) { return /^\w+$/.test(s); })
这个正则表达式模式在新行中分隔数值,其中包含特殊字符,如.
,,
,#
等。
var val = [1234,1213.1212, 1.3, 1.4]
var re = /[0-9]*[0-9]/gi;
var str = "abc123,def456, asda12, 1a2ass, yy8,ghi789";
var re = /[a-z]{3}\d{3}/g;
var list = str.match(re);
document.write("<BR> list.length: " + list.length);
for(var i=0; i < list.length; i++) {
document.write("<BR>list(" + i + "): " + list[i]);
}
这将只在列表中获得“abc123”代码样式,而不是其他内容。
可能是你可以使用拆分功能
var st = "abc123,def456,ghi789";
var res = st.split(',');