1

我想检查给定字符串中多个字符串的可用性(不使用循环)。

my_string = "How to find occurence of multiple sting in a given string using javascript RegExp";
// search operated on this string
// having a-z (lower case) , '_' , 0-9 , and space

// following are the strings wanted to search .( having a-z , 0-9 , and '_')

search_str[0]="How";
search_str[1]="javascript";
search_str[2]="sting";
search_str[3]="multiple";
  • 我不需要他们的位置。
  • 我只需要知道所有 search_str 都必须在 my_string 中
  • search_str 的顺序永远不会影响结果。

有没有可用的正则表达式?

更新:我错过了什么

在答案中我发现这个正在解决上述问题

if (/^(?=.*\bHow\b)(?=.*\bjavascript\b)(?=.*\bsting\b)(?=.*\bmultiple\b)/.test(subject)) {
    // Successful match
}

但在这种情况下,它不起作用。

m_str="_3_5_1_13_10_11_";
search_str[0]='3';
search_str[1]='1';
tst=new RegExp("^(?=.*\\b_"+search_str[0]+"_\\b)(?=.*\\b_"+search_str[1]+"_\\b)");
if(tst.test(m_str)) alert('fooooo'); else  alert('wrong');
4

1 回答 1

5
if (/^(?=.*\bHow\b)(?=.*\bjavascript\b)(?=.*\bsting\b)(?=.*\bmultiple\b)/.test(subject)) {
    // Successful match
}

这假设您的字符串不包含换行符。如果是这样,您需要将所有.s 更改为[\s\S].

我使用了单词边界锚来确保Howardresting不意外地提供匹配。如果您确实想允许这样做,请删除\bs。

解释:

(?=...)是一个前瞻断言:它在字符串中前瞻,以检查封闭的正则表达式是否可以 在当前位置匹配,而无需实际消耗匹配字符。因此,一连串的先行操作就像一系列正则表达式(锚定到字符串的开头 by ^),它们与逻辑&&运算符组合在一起。

于 2013-03-01T06:47:29.720 回答