V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
rekulas
V2EX  ›  程序员

十年程序员难到了一个正则上面

  •  
  •   rekulas ·
    del-xiong · 2022-11-16 17:06:18 +08:00 · 1020 次点击
    这是一个创建于 737 天前的主题,其中的信息可能已经有所发展或是发生改变。

    非科班出身正则基础不够扎实

    今天遇到一个匹配需求(1(2(,需要根据括号匹配到每一个数字,本来我以为很简单,但是始终只能匹配到 1 ,才发现这个的匹配值互相冲突了 (1(和(2(,根据我的理解匹配到 1 的时候索引已经移动到 2(了,要想匹配(2(就必须回溯一位,但是一般只有失败才回溯,这种成功了回溯的不清楚怎么写,试过 lookbehind 等方法貌似也不行

    (别纠结为什么一定要用括号匹配而不是直接[\d]+,真实情况比这复杂这是演示数据,而且已经通过其他方式解决了,但我还是想知道这个怎么写正则)

    aijam
        1
    aijam  
       2022-11-16 17:50:42 +08:00   ❤️ 1
    每个 regex engine 实现不一样,比如 python 里面
    (?=...) 是 lookahead
    (?<=...) 是 lookbehind
    所以你可以写 r"(?<=\()\d+(?=\()"
    rekulas
        2
    rekulas  
    OP
       2022-11-16 17:52:59 +08:00
    @aijam 感谢了 666 那是我写错了
    DrakeXiang
        3
    DrakeXiang  
       2022-11-16 22:12:59 +08:00
    难道不是 /\((\d)/g 就行了么?
    qeqv
        4
    qeqv  
       2022-11-17 04:21:02 +08:00
    ```
    const e = /\(\d\(/g;
    let result
    while((result=e.exec("(1(2(3(4"))!=null){
    console.log(result[0]);
    e.lastIndex--;
    };
    ```
    手动回溯😂
    rekulas
        5
    rekulas  
    OP
       2022-11-17 10:21:13 +08:00
    @qeqv 可以 已经有分词器雏形了 🤣
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2769 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 19ms · UTC 11:46 · PVG 19:46 · LAX 03:46 · JFK 06:46
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.