Соответствует регулярному выражению до первого появления специального символа '->' - PullRequest
1 голос
/ 06 октября 2019

Я новичок в регулярном выражении и пытался сопоставить выражение до специального символа / с. Если совпадения существуют до специального символа, возвращайте его, в противном случае ничего не возвращайте.

Вот демо 1004 *.

Моя цель - вернуть совпадение, если оно найдено до '-> 'специальный символ в противном случае ничего не возвращает. Он не должен возвращать совпадения после специального символа '->.

Regexp: /()()(\[[^\]]+\])\s*(-[->])(.*)/g // В третьей группе будет возвращен фактический результат

Например, данные:

[AAA] -> [BBB] -> [CCC] // В этом случае необходимо сопоставить [AAA]

AAA -> [BBB] -> [CCC] // В этом случае невернуть [BBB], вместо этого ничего не возвращать, как раньше, специальный символ '->', совпадений нет.

Пожалуйста, помогите мне с этим. Заранее спасибо.

Ответы [ 3 ]

2 голосов
/ 06 октября 2019

Используйте это регулярное выражение

^\[(.*?)\] ->

и захватите группу 1 (внутри скобок).

См. Этот тест регулярного выражения

2 голосов
/ 06 октября 2019

Это то, что вы хотите?

^\[[^\]]+\](?=\h*->)

Объяснение:

^               # beginning of string
  \[            # opening squarre bracket
    [^\]]+      # 1 or more any character that is not closiing bracket
  \]            # closing bracket
  (?=           # start positive lookahead, make sure we have after:
    \h*         # 0 or more horizontal spaces
    ->          # literally ->
  )             # end lookahead

Демо

1 голос
/ 08 октября 2019

Я не до конца понимаю проблему, просто скопирую здесь несколько догадок, которые могут приблизить вас к тому, что вы пытаетесь выполнить:

^()()((\[[^\]]*\]))\s*->(.*)

Демо 1

()()(\[[^\]]+\])\s*->(\s*\[[^\]]+\]\s*->\s*\[[^\]]+\])

Демонстрация 2

()()(\[[^\]\r\n]+\])\s*->\s*(\[[^\]\r\n]+\]\s*->\s*\[[^\]\r\n]+\])

Демонстрация 3

const regex = /^()()((\[[^\]]*\]))\s*(->)(.*)/gm;
const str = `[AAA] -> [BBB] -> [CCC]
AAA -> [BBB] -> [CCC]`;
let m;

while ((m = regex.exec(str)) !== null) {
    // This is necessary to avoid infinite loops with zero-width matches
    if (m.index === regex.lastIndex) {
        regex.lastIndex++;
    }
    
    // The result can be accessed through the `m`-variable.
    m.forEach((match, groupIndex) => {
        console.log(`Found match, group ${groupIndex}: ${match}`);
    });
}

Схема RegEx

jex.im визуализирует регулярные выражения:

enter image description here

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...