链接到 regex101
我正在实现一个简单的NLP算法。我已经实现了通过循环原始字符串来辅助正则表达式的解决方案,但现在我想看看是否能用纯正则表达式来完成。
我无法弄清楚如何让’build’组遵循否定前瞻。我试图捕获[“自然语言处理”算法] 任何帮助都将不胜感激,谢谢
$subject_string = <<<'subject_string'Projects I've built & Plan to build. HackMatch.io (May 2020 onward), As of October 2020, I intend to start implementing "Natural Language Processing" algorithms in PHP when I have time. I'll then use PHP to upload the results to big data tech (e.g. BigQuery) to create some data visualizations.subject_string;$pattern = <<<'pattern'/\b(?'verb'build|make|implementing)(?'build'.+?(?!build|make|implementing)) (?=\bin\b|\bon\b)(?:build|make|implementing)??/ixpattern;preg_match_all($pattern, $subject_string, $matches)
回答:
你可以使用
/\b(?'verb'build|make|implementing)\s*(?'build'(?:(?!(?&verb)).)*?) (?=\s*\b(?:in|on)\b)/ixs
查看 正则表达式演示。 详细信息:
\b
– 一个单词边界(?'verb'build|make|implementing)
– “verb”组:括号内的单词之一\s*
– 零个或多个空白字符(?'build'(?:(?!(?&verb)).)*?)
– “build”组:任何字符,零个或多个出现,但尽可能少,不以”verb”组中定义的任何字符序列开始\s*
– 零个或多个空白字符(?=\b(?:in|on)\b)
– 一个正向先行断言,匹配紧随其后的位置,后面跟着完整的单词in
或on
。