Regex “不包含”模式问题用于自然语言处理

链接到 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) – 一个正向先行断言,匹配紧随其后的位置,后面跟着完整的单词 inon

Related Posts

Keras Dense层输入未被展平

这是我的测试代码: from keras import…

无法将分类变量输入随机森林

我有10个分类变量和3个数值变量。我在分割后直接将它们…

如何在Keras中对每个输出应用Sigmoid函数?

这是我代码的一部分。 model = Sequenti…

如何选择类概率的最佳阈值?

我的神经网络输出是一个用于多标签分类的预测类概率表: …

在Keras中使用深度学习得到不同的结果

我按照一个教程使用Keras中的深度神经网络进行文本分…

‘MatMul’操作的输入’b’类型为float32,与参数’a’的类型float64不匹配

我写了一个简单的TensorFlow代码,但不断遇到T…

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注