加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

基于受约束的分割符分割字符串

发布时间:2020-12-14 02:28:33 所属栏目:百科 来源:网络整理
导读:问题:以“|”为分割符分割 abc|abc()|abc(a)|abc(a|b)abc 但括号内“|”不作为分割点,即分割后结果为 abc ,abc() , abc(a) ,abc(a|b)abc。 //问题的关键是如何排除括号中的"|"匹配。我的思路是把括号中的"|"予以标记,使其不命中匹配,自然的就会想到把

问题:以“|”为分割符分割 abc|abc()|abc(a)|abc(a|b)abc 但括号内“|”不作为分割点,即分割后结果为 abc ,abc() , abc(a) ,abc(a|b)abc。


//问题的关键是如何排除括号中的"|"匹配。我的思路是把括号中的"|"予以标记,使其不命中匹配,自然的就会想到把这些

//特别的"|"替换成特别的字符串,作为例子,这里我用"&"替换这些特殊的"|".接下来又会产生一个新问题,如何识别这些 //特别的"|"? 可以发现我们的目标中涉及到的特殊的"|"可以这样定义:所有在成对的括号中的"|".接下来的思路就是找到 //所有成对的括号,并把里面的"|"替换为对于字符串而言特别的字符串(此处为&),接着再利用pattern=/(.*?)|/gm 查询,//获得查询结果后把对应的字串还原为原来的状态就行了(即把"&"替换会"|").现在唯一遗留的问题就是如何找到成对的括号? //我们知道,括号的匹配关系是从内向外的顺序匹配的,所有从内层向外逐层扫描成对括号。找成对的括号不是目的,而是为了 //标记里面的"|",通过模式 var pattern=/([^(]*?)/gm 把最里层的成对括号查询出,并替换其中的"|",同时把左右括号也 //替换为其他特别的字符串(left="@"; right="#";),这样才不会影响外面一层的扫描替换。把分割得的结果中的特殊字符替换回去 //就行了。下面是代码: */ var text="abc|abc()|abc(a)|abc(a|b)abc"; var left="@"; var right="#"; var or="&"; var noKH=""; var noOr=""; var textNoOrInKH=text; var matches=""; var pattern=/([^(]*?)/gm; //匹配成对的括号 while((matches=pattern.exec(text))){ //alert(matches[0]); //把匹配字符串中的"|"、"("、")"替换掉 noKH=left+matches[0].substring(1,matches[0].length-1)+right; //alert("noKH:"+noKH); noOr=noKH.replace(/(|)/,or); //alert("noOr:"+noOr); textNoOrInKH=textNoOrInKH.replace(matches[0],noOr); //alert(textNoOrInKH); } //获取目标字串 pattern=/(.*?)|/gm; var resultList=new Array(); textNoOrInKH+="|" while((matches=pattern.exec(textNoOrInKH))){ //alert(matches[0]); resultList.push(matches[1]); //alert(resultList); } //把目标字串中的特殊字符还原 for(var i=0;i<resultList.length;i++){ resultList[i]=resultList[i].replace(new RegExp(left,"gm"),"("); //alert(resultList); resultList[i]=resultList[i].replace(new RegExp(right,")"); //alert(resultList); resultList[i]=resultList[i].replace(new RegExp(or,"|"); //alert(resultList); } alert(resultList); </script>

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读