本站资源收集于互联网,不提供软件存储服务,每天免费更新优质的软件以及学习资源!

如何使用正则表达式提取特定HTML结构中的内容?

网络教程 app 1℃

如何使用正则表达式提取特定HTML结构中的内容

正则表达式匹配特定 html 结构

通过正则表达式,我们可以解析 html 文本并提取所需数据。以下是一个实例,展示了如何通过正则表达式匹配特定 html 结构并提取其中的内容:

给定以下 html 结构:

<div class="content"> <h1>标题xxxxx</h1> <div class="block-1"> <ul class="article"><li>文章标题1</li><li>文章标题2</li><li>文章标题3</li> </ul> </div> <div class="block-2"> <ul class="article"><li>文章标题1</li><li>文章标题2</li><li>文章标题3</li> </ul> </div> <div class="block-3"> <ul class="article"><li>文章标题1</li><li>文章标题2</li><li>文章标题3</li> </ul> </div></div>

我们希望提取 class 为 “block-2” 的 div 中所有 li 标签内的值。

使用以下正则表达式可以实现上述目的:

/(?<=block-1.*<li>).*?(?=</li>.*block-2)/g

该正则表达式包含以下部分:

(?):匹配以 class 为 “block-1” 的 div 内 li 标签之前的任何内容。.*?:非贪婪匹配 li 标签的内容(包括子元素)。(?=.*block-2):匹配以 class 为 “block-2” 的 div 内 li 标签之后的任何内容。

利用该正则表达式,我们可以如下提取所需数据:

let str = strhtml; // html 文本let removeenter = str.replace(/[]/g, “”).replace(/[ ]/g, “”).match(/(?<=block-1.*<li>).*?(?=</li>.*block-2)/g);console.log(removeenter);

输出结果:

["文章标题1", "文章标题2", "文章标题3"]

以上就是如何使用正则表达式提取特定 HTML 结构中的内容?的详细内容,更多请关注范的资源库其它相关文章!

转载请注明:范的资源库 » 如何使用正则表达式提取特定HTML结构中的内容?

喜欢 (0)