我有一个文档,我需要从中提取一些数据。文档包含这样的字符串
Text:"How secure is my information?"
我需要提取文字后双引号中的文本 Text:
How secure is my information?
如何在 Javascript 中使用正则表达式执行此操作
我有一个文档,我需要从中提取一些数据。文档包含这样的字符串
Text:"How secure is my information?"
我需要提取文字后双引号中的文本 Text:
How secure is my information?
如何在 Javascript 中使用正则表达式执行此操作
Lookbehind 断言最近已针对 JavaScript 完成,并将出现在 ECMA-262 规范的下一次发布中。它们在 Chrome 66 (Opera 53) 中受支持,但在撰写本文时其他主要浏览器均不支持。
var str = 'Text:"How secure is my information?"',
reg = /(?<=Text:")[^"]+(?=")/;
str.match(reg)[0];
// -> How secure is my information?
较旧的浏览器不支持 JavaScript 正则表达式中的后视。您必须使用捕获括号来代替这样的表达式:
var str = 'Text:"How secure is my information?"',
reg = /Text:"([^"]+)"/;
str.match(reg)[1];
// -> How secure is my information?
然而,这不会涵盖所有的后视断言用例。
我只想补充一点:JavaScript不支持像(?<= )
或(?<! )
.
但它确实支持像(?= )
or那样的前瞻(?! )
。
你可以这样做:
/Text:"(.*?)"/
解释:
Text:"
: 字面上匹配.*?
: 以非贪婪的方式匹配任何东西()
: 捕捉比赛"
: 匹配文字 "
/ /
: 分隔符string.match(/Text:"([^"]*)"/g)
<script type="text/javascript">
var str = 'Text:"How secure is my information?"';
var obj = eval('({'+str+'})')
console.log(obj.Text);
</script>