这是我之前问题的后续。我意识到我需要更具体地说明我的regex案例,以获得适用于我的案例的答案。
我已经与这个正则表达式斗争了很长一段时间(也使用我上一个问题的答案),我似乎无法构建我需要的东西。
我需要将所有字符串中出现的两个重复出现的单引号'
替换为\'
(因此字符串内部意味着单引号'somesString'之间有或没有双引号发生'
)。这是因为在一种语言(语法)中,字符串中的引号使用<code>‘转义。
这里有一个例子(实际的例子可以包含用< code >、分隔的多个字符串,但是< code >、当然也可以出现在字符串中):
'word'''',and''','another'',''word','''test',X,'',FUNCTION('A'' B C D')
"--------------","----------------","------",-,"",FUNCTION("---------")
" ++++ ++"," ++ ++ ","++ ", ,"", (" ++ ")
1 2 3 4 5 6 7
替换后的结果应为:
'word\'\',and\'','another\',\'word','\'test',X,'',FUNCTION('A\' B C D')
< code>
是必需的匹配。示例下一行中的字符串(由< code>"表示)中的左引号和右引号不应是匹配的一部分(这些单引号标记了可以出现双引号的字符串的实际开头或结尾)。
当我看到它时,它看起来很简单,我可以立即从字符串中指出双引号,但我无法在我的模式中正确定义它。
另一种解决方案是用双引号替换开始和结束引号,并用单引号替换单引号的双出现:
'word'''',and''','another'',''word','''test',X,'',FUNCTION('A'' B C D')
"--------------","----------------","------",-,"",FUNCTION("---------")
++++ ++ , ++ ++ , ++ , , , ( ++ )
1 2 3 4 5 6 7
在这种情况下,替换
后的结果将是:
"word'',and'","another','word","'test",X,"",FUNCTION("A' B C D")
这是准备好的小提琴来测试模式
对于它的帮助,我想出了不工作:
/'(('{2})+)*'/g
和
/'[^']*(('')*)*[^']*'/g
和
/('(('{2})*)*')[^,$]/g
这不是问题:只需匹配这些字符串并使用替换回调方法将双撇号替换为单撇号:
var expression = /'([^']*(?:''[^']*)*)'/g;
var replacer = function(m, g1){
return g1 ? "'" + g1.replace(/''/g, '\'') + "'" : "''";
}
看这个更新的小提琴
'([^']*(?:''[^']*)*)'
regex仅匹配捕获单引号之间内容的单引号字符串文字。
模式匹配:
'
-前导单引号
([^']*(?:''[^']*)*)
-第1组捕获< code >“”中的任何0字符: < ul > [^']*
-除单引号之外的0个字符(?:''[^']*)*
- 0序列: < Li > < code >“”-两个连续的撇号
[^']*
-除单引号之外的0个字符因此,当我们执行替换时,我们检查组1匹配并且不为空。如果是,我们只返回< code>'',如果不是,我们借助replace回调中的< code>"'" g1.replace(/''/g,' \'') "'"将双撇号替换为单撇号。
我正在编写一个正则表达式来解析包含标记字段的行。标签出现在等号之前,内容出现在等号之后,用单引号或双引号括起来。对于大多数字段,内容都用单引号括起来。如果字段的内容包含单引号,则该字段用双引号括起来。例如: 我的正则表达式有效,除非字段用双引号括起来。 在Debuggex中测试 在Regexr中测试 对于上面示例中标记为a的字段,a=“'D08/APPL'”,a由捕获组1匹配,后面的单引号由捕获组
问题内容: 我有一个输入字符串 这个或“那个或”或“这个或那个” 应该翻译成 这个|| “那个或” || “这个或那个” 因此,尝试是在一个字符串中查找一个字符串(或)的出现并将其替换为另一个字符串(||)。我尝试了以下代码 输出是 这个|| “那个或” || ‘这个|| 那’ 问题是单引号内的字符串也被替换了。至于代码,样式仅是示例。当我开始工作时,我将编译模式并重用它。 问题答案: 试试这个正
我面临一个挑战,要以以下格式匹配输入: 输入由key=value对组成。关键字以斜杠开头。值可以是数字或引号中的字符串。 该值可以选择性地包含转义引号,即引号后面跟着引号(“”)。这种转义引号应该被视为价值的一部分。不需要检查转义引号是否平衡(例如,由另一个转义引号结束)。 正则表达式应该匹配序列中给定的key=value部分,并且对于长输入(例如value是10000个字符)不应该中断。
我想解析以下字符串: 我正在使用,所以我这里缺少的是正确的正则表达式。规则是正则表达式必须: 隔离任何单个单词 任何用双引号括起来的子字符串都是匹配的 单词中的双引号必须忽略(稍后我将用空格替换它们)。 因此,结果匹配应该是: < li>w1 w"2 < li>w3 < li>| < li>w4 < li>w"5 < li>w6 w7 双引号是否包含在双引号括起来的子字符串中是无关紧要的(例如,1
我正在尝试匹配这些字符串: 单引号中不能包含双引号 双引号中没有双引号 单引号内的单引号-单引号只能包含内部的文本 我想出了以下正则表达式: 但它不起作用。
我需要替换以下字符串中的引号。 最终输出应该是“这是test()ing和test()ing”; i、 e仅当它以“test()开头,以”结尾时才替换。中间的文本保持不变。 这个坏了。 请为同样的问题推荐合适的正则表达式。