C_4510471 2015-07-07 05:18 采纳率: 20%
浏览 2624
已采纳

【已解决】正则 零宽断言 匹配一个单词后的第一个数字

比如
[CM][bt][02][03]
我想匹配 02

我的正则是这样写的:

i)(?<=\bCM\b(\D*)?)\d+(?=\D)

但无法匹配成功,请问该怎样改呢?

感谢各位!
正则本身没错...错的是
PCRE 8.34–8.35 UTF-8 does not support variable repetition inside lookbehind or alternatives of different lengths inside groups inside lookbehind

  • 写回答

1条回答

  • rita_leng 2015-07-19 06:03
    关注
                var str = '[CM][bt][02][03]';
        str = str.replace(/\[/gi,"@").replace(/\]/gi,"@");
        var reg = /\w+@{2}\d+/gi;
        var arrMatches = str.match(reg);
            for(var i = 0 ; i < arrMatches.length; i++){
                console.log( arrMatches[i].replace(/\D/gi,""));
            }
    由于[]是正则表达式的元字符,先把它替换成@,查找单词开始,跟着@@,再数字的表达式,获取表达式后去除非数字的,最后得到数字02                  
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 求TYPCE母转母转接头24PIN线路板图
  • ¥100 国外网络搭建,有偿交流
  • ¥15 高价求中通快递查询接口
  • ¥15 解决一个加好友限制问题 或者有好的方案
  • ¥15 急matlab编程仿真二阶震荡系统
  • ¥20 TEC-9的数据通路实验
  • ¥15 ue5 .3之前好好的现在只要是激活关卡就会崩溃
  • ¥50 MATLAB实现圆柱体容器内球形颗粒堆积
  • ¥15 python如何将动态的多个子列表,拼接后进行集合的交集
  • ¥20 vitis-ai量化基于pytorch框架下的yolov5模型