gpt4 book ai didi

java - 如何使用正则表达式从 cucumber 特征文件中提取特定场景

转载 作者:行者123 更新时间:2023-11-30 08:01:29 24 4
gpt4 key购买 nike

我有一个 cucumber 特征文件,其中包含多个场景,每个场景都有不同的 And。我正在使用 Java 正则表达式来解析该文件,并希望根据 And 中的文本提取特定场景。

例如:

功能:测试东西

场景:

lady swallows fly Given a lady and lady swallows a "fly" then lady lives

场景:

lady swallows spider Given a lady and lady swallows a "fly","spider" then lady lives

场景:

lady swallows everything Given a lady and lady swallows a "fly","spider","cat","dog","cow" then lady Dies

场景:

lady swallows everything except the dog Given a lady and lady swallows a "fly","spider","cat","cow" then lady Dies

我想提取包含 dog 的场景并将其转储到单独的文件中。在我的现实生活中,dog=帐号 并关联到多个自动加载到本地数据库中的 SQL 提取。这是一个单一场景,位于一个功能文件中,是数百个功能文件中的一个。因此,这不是在场景顶部使用 @run 的简单情况。我实际上正在提取场景和相关文件,以便将它们放入沙箱中。

到目前为止我拥有的正则表达式是:

.*?dog.*Scen

但是从场景的第一个实例中选择的场景超出了我想要的范围。

相反,我想退出该组:

场景:

lady swallows everything Given a lady and lady swallows a "fly","spider","cat","dog","cow" then lady Dies

有人知道我怎样才能退出该组吗?

最佳答案

如果场景由\n 分隔,请尝试使用:

^[^\n]+\bdog\b[^\n]+

DEMO

如果是连续字符串,请尝试:

(?=Scenario).+?\bdog\b.+?(?=Scenario|$)

DEMO

关于java - 如何使用正则表达式从 cucumber 特征文件中提取特定场景,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31857558/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com