我正在尝试获取正确的正则表达式来匹配包含特定单词的行的第 N 个单词。
例如,如果我有这样的输入:
this is the first line - blue
this is the second line - green
this is the third line - red
我想匹配包含单词“second”的行的第七个单词并返回green
.
我在用着Rubular来测试正则表达式。
我已经尝试过这个正则表达式但没有成功 - 它匹配下一行:
(.*second.*)(?<data>.*?\s){7}(.*)
另一个输入示例:
this is the Foo line - blue
this is the Bar line - green
this is the Test line - red
我想匹配包含单词“red”的行的第四个单词并返回Test
.
我想要匹配的单词可以是before or after我用来选择该行的词。
您可以使用它来匹配包含以下内容的行second
并抓住第七个词:
^(?=.*\bsecond\b)(?:\S+ ){6}(\S+)
确保全局和多行标志处于活动状态。
^
匹配行的开头。
(?=.*\bsecond\b)
是一个积极的前瞻,以确保有这个词second
在该特定行中。
(?:\S+ ){6}
匹配 6 个单词。
(\S+)
将获得第 7 个。
正则表达式101演示
您可以将相同的原则应用于其他要求。
包含一行red
并得到第四个词...
^(?=.*\bred\b)(?:\S+ ){3}(\S+)
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)