我正在使用 Java 解析 JavaScript 文件。因为范围与我使用它的环境中的预期不同,所以我试图替换 ie 的每个实例
test = value
和
window.test = value
以前,我只是在使用
writer.append(js.getSource().replaceAll("test", "window.test"));
这显然是不可推广的,但对于一个固定的数据集,它工作正常。
但是,在我应该使用的新文件中,旧文件的更新版本,我现在必须处理
window['test'] = value
和
([[test]])
我不想test
在这两种情况下匹配,而且似乎只有这两种情况有新格式。所以我的计划是现在做一个正则表达式来匹配除了'
和[
作为第一个字符之外的任何东西。那将是([^'\[])test
; 但是,我实际上并不想替换第一个字符 - 只要确保它不是我不想匹配的两个字符之一。
这对我来说是一个新情况,因为我没有用 RegExps 进行替换,只是模式匹配。所以我环顾四周,找到了我认为的解决方案,称为“非捕获组”。Oracle 页面上的解释听起来像我正在寻找的内容,但是当我将正则表达式重写为 be(?:[^'\\[])test
时,它的行为就像我没有更改任何内容一样 - 替换前面的字符test
。我环顾了 StackOverflow,但我发现的只是让我更加确信我正在做的事情应该有效。
我做错了什么,它没有按预期工作?我在滥用模式吗?