V2EX = way to explore
V2EX 是一个关于分享和探索的地方
Sign Up Now
For Existing Member  Sign In
• 请不要在回答技术问题时复制粘贴 AI 生成的内容
rekulas
V2EX  ›  程序员

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

  •  
  •   rekulas ·
    del-xiong · Nov 16, 2022 · 1357 views
    This topic created in 1257 days ago, the information mentioned may be changed or developed.

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

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

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

    aijam
        1
    aijam  
       Nov 16, 2022   ❤️ 1
    每个 regex engine 实现不一样,比如 python 里面
    (?=...) 是 lookahead
    (?<=...) 是 lookbehind
    所以你可以写 r"(?<=\()\d+(?=\()"
    rekulas
        2
    rekulas  
    OP
       Nov 16, 2022
    @aijam 感谢了 666 那是我写错了
    DrakeXiang
        3
    DrakeXiang  
       Nov 16, 2022
    难道不是 /\((\d)/g 就行了么?
    qeqv
        4
    qeqv  
       Nov 17, 2022
    ```
    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
       Nov 17, 2022
    @qeqv 可以 已经有分词器雏形了 🤣
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   5816 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 42ms · UTC 07:32 · PVG 15:32 · LAX 00:32 · JFK 03:32
    ♥ Do have faith in what you're doing.