我很难得到一个看似简单的Regexp。我试图抓住字符串中方括号之间最后出现的单词字符。我的代码:
pattern = /\[(\w+)\]/g;
var text = "item[gemstones_attributes][0][shape]";
if (pattern.test(text)) {
alert(RegExp.lastMatch);
}
上面的代码是输出“gemstones_attributes”,我想让它输出“shape”。为什么这个正则表达式不起作用,或者我获取最后一个匹配的方法有问题?我确信我犯了一个明显的错误——正则表达式从来都不是我的强项。
编辑:在某些情况下,字符串不会以右括号结束。
我认为您的问题出在您的正则表达式中,而不是在您的 src 行 .lastMatch 中。
正则表达式只返回方括号的第一个匹配项,而不是所有匹配项。你可以试着在你的正则表达式中添加一些组——通常你会得到所有的匹配。
克里基特
RegExp.lastMatch提供最后一个正则表达式的匹配。这不是课文中的最后一场比赛。
正则表达式从左到右解析,并且是贪婪的。因此,你的正则表达式匹配第一个“[”,它会看到并抓取其中的单词。当你调用lastMatch时,它会给你最后一个匹配的模式。你需要的是先匹配你能匹配的所有内容。*然后匹配你的模式。
您可以在您的模式之前贪婪地匹配尽可能多的匹配,这将导致您的组仅匹配最后一个匹配:
pattern = /.*\[(\w+)\]/g;
var text = "item[gemstones_attributes][0][shape]";
var match = pattern.exec(text);
if (match != null) alert(match[1]);
有没有人试图描述与正则表达式匹配的正则表达式? 由于重复的关键字,这个主题几乎不可能在网上找到。 它可能在实际应用程序中不可用,因为支持正则表达式的语言通常具有解析它们的方法,我们可以将其用于验证,以及一种在代码中分隔正则表达式的方法,可用于搜索目的。 但是我仍然想知道匹配所有正则表达式的正则表达式是什么样子的。应该可以写一个。
给定下面的字符串 [NeMo(PROD)]10.10.100.100(EFA-B-3)[博科FC-Switch]传感器:电源#1(SNMP自定义表)关闭(无此名称(SNMP错误#2)) 我尝试获取多个匹配项以提取以下值: 因为我是正则表达式的初学者,所以我试图定义一些“规则”: 提取第一个圆括号内的第一个值,例如PROD 提取第一个闭合方括号和第二个开口圆括号之间的值,例如10.10.100.10
我有一个regex101正确工作的regex: 有2个匹配,如预期的。 现在我想用std的regex_token_iterator拆分相同的: 这可以很好地编译,但没有任何东西被打印到stdout。 我认为正则表达式必须以其他方式编写,你能指出我的错误吗?
我们得到了一些这样的内容:
主要内容:基本模式匹配,字符簇,确定重复出现基本模式匹配 一切从最基本的开始。模式,是正则表达式最基本的元素,它们是一组描述字符串特征的字符。模式可以很简单,由普通的字符串组成,也可以非常复杂,往往用特殊的字符表示一个范围内的字符、重复出现,或表示上下文。例如: 这个模式包含一个特殊的字符 ^,表示该模式只匹配那些以 once 开头的字符串。例如该模式与字符串 "once upon a time" 匹配,与 "There once was
问题内容: 设置修饰符后,为什么Java子匹配项停止工作? 上面的方法很好,is 和is 。 上面的内容忽略了我的捕获组。以下是唯一有效的解决方案吗? 编辑: 我再次高兴地告诉您,十年后您现在可以执行此操作(.matchAll已添加到规范中) 问题答案: 我很惊讶地发现我是第一个回答我十年前一直在寻找答案的人(答案尚不存在)。我还希望实际的规范作者会在我之前回答它;)。 .matchAll 已被添
我使用wiremock来模拟某些请求及其相应的响应,但我试图添加一个正则表达式。不幸的是,这只会引发一个异常,表明请求不匹配。 我也试过了 我发送的请求是