0

0

提取 HTML 文本中两关键词之间的全部内容(含标签)

花韻仙語

花韻仙語

发布时间:2026-02-16 13:04:02

|

684人浏览过

|

来源于php中文网

原创

提取 HTML 文本中两关键词之间的全部内容(含标签)

本文介绍如何使用 R 的 stringr 包精准提取 HTML 字符串中两个指定关键词(如 "Regeste" 和 "Sachverhalt")之间的完整原始内容(含所有 HTML 标签与空白字符),适用于网页结构化文本抽取任务。

本文介绍如何使用 r 的 stringr 包精准提取 html 字符串中两个指定关键词(如 "regeste" 和 "sachverhalt")之间的**完整原始内容(含所有 html 标签与空白字符)**,适用于网页结构化文本抽取任务。

在网页数据抓取(如使用 rvest 解析 HTML)后,常需从原始 HTML 字符串中定位并截取特定语义区块——例如瑞士联邦法院判决书中的

所标记的“摘要”(Regeste)和“案情”(Sachverhalt)部分。此时,简单使用 str_extract(html, "Regeste.*Sachverhalt") 会失败:默认点号 . 不匹配换行符,且贪婪匹配易越界;更关键的是,我们往往需要包含起始/结束关键词邻近的 HTML 结构(如
...),而非仅关键词之间的纯文本。

正确做法是采用支持跨行匹配、支持非捕获断言的正则表达式,并借助 stringr::str_extract() 实现精准提取。核心技巧有三:

  1. 启用跨行匹配:使用 [sS](匹配任意空白或非空白字符)替代 .,确保涵盖换行符 、制表符 等;
  2. 避免捕获边界词本身:使用正向先行断言 (?
  3. 兼顾大小写灵活性:通过 Regeste|regeste 和 Sachverhalt|sachverhalt 支持常见大小写变体,提升鲁棒性。

以下是完整可运行示例:

Cleanup.pictures
Cleanup.pictures

智能移除图片中的物体、文本、污迹、人物或任何不想要的东西

下载
library(dplyr)
library(stringr)

# 示例 HTML(已简化,保留关键结构)
html <- '<a name="idp341456"></a><div class="big bold">Urteilskopf</div>
<br>147 IV 65<br><br><br><div class="paraatf">8. Auszug aus dem Urteil der Strafrechtlichen Abteilung i.S. A. gegen Generalstaatsanwaltschaft des Kantons Bern, B. und Verein C. (Beschwerde in Strafsachen)</div>
<div class="paraatf">6B_440/2019 vom 18. November 2020</div>
  <a name="idp342784"></a><br><div id="regeste" lang="de">
<div class="big bold">Regeste</div>
<br><div class="paraatf"><span class="artref">Art. 28 Abs. 1 StGB</span>; Strafbarkeit der Medien; keine Anwendbarkeit von <span class="artref">Art. 28 Abs. 1 StGB</span> beim "Teilen" und Kommentieren eines fremden Beitrags auf Facebook.  <div class="paratf">Grundsatz der exklusiven Strafbarkeit des Autors bei Mediendelikten (E. 5.1-5.3). Der in <span class="artref">Art. 28 Abs. 1 StGB</span> verankerte Begriff des "Mediums" umfasst nicht nur sämtliche Kommunikationsträger, sondern auch Kommunikationsmittel (E. 5.4.1-5.4.3). </div>
<div class="paratf">Die Anwendbarkeit von <span class="artref">Art. 28 Abs. 1 StGB</span> erfordert zunächst, dass das Medienerzeugnis der Öffentlichkeit zugänglich gemacht wird. Das gilt grundsätzlich für Beiträge auf Social Media-Plattformen, soweit sie nicht durch persönliche Einstellungen nur für einen beschränkten Personenkreis verfügbar sind (E. 5.4.4). </div>
<div class="paratf">Die Anwendbarkeit von <span class="artref">Art. 28 Abs. 1 StGB</span> bedingt zusätzlich, dass sich die strafbare Handlung in der Veröffentlichung erschöpft. <span class="artref">Art. 28 Abs. 1 StGB</span> privilegiert dabei alle innerhalb der für das Medium typischen Herstellungs- und Verbreitungskette tätigen Personen. Der weite Medienbegriff setzt voraus, dass im Einzelfall geprüft werden muss, wer Teil der medientypischen Kette ist. Vorliegend verneint beim "Teilen" und Kommentieren eines fremden bereits veröffentlichten Beitrags auf Facebook (E. 5.5 und 5.6). </div>
</div>
</div>
  <a name="idp232400"></a>
  <a name="idp246448"></a>
  <br><div>
<a name="idp404656"></a><span class="big bold" id="sachverhalt">Sachverhalt</span> <span class="small">ab Seite 66</span>
</div>
<br><div class="paraatf">'

df <- data.frame(html = html, stringsAsFactors = FALSE)

# ✅ 正确提取:Regeste 与 Sachverhalt 之间的全部内容(含标签、换行、空格)
df <- df %>%
  mutate(
    regeste_block = str_extract(
      html,
      "(?<=Regeste|regeste)[\s\S]*(?=Sachverhalt|sachverhalt)"
    )
  )

# 查看提取结果长度与前100字符验证
cat("提取内容长度:", nchar(df$regeste_block), "
")
cat("前100字符预览:
", substr(df$regeste_block, 1, 100), "...
")

⚠️ 注意事项:

立即学习前端免费学习笔记(深入)”;

  • 勿用 .* 替代 [sS]*:. 默认不匹配换行符,会导致跨多行的 HTML 内容截断;
  • 避免贪婪陷阱:若 HTML 中多次出现 “Sachverhalt”,[sS]* 会匹配到最后一个出现位置。如需最短匹配(即首次闭合),可改用 [sS]*?(非贪婪模式),但需确保上下文唯一性;
  • HTML 解析优先于正则:对复杂、嵌套深或格式不规范的 HTML,建议优先使用 rvest::html_nodes() 配合 CSS/XPath 定位(如 html_node("#regeste")),正则提取应作为轻量级、结构稳定场景的补充方案;
  • 编码与转义:确保输入字符串为 UTF-8 编码;若 HTML 含实体(如 &),提取后需用 xml2::xml_text() 或 stringi::stri_unescape_html() 进一步处理。

掌握该方法后,你可快速构建判决书章节切片、法律条文引用段落抽取、网页文档结构化归档等自动化流程——精准、简洁、可复现。

相关文章

HTML速学教程(入门课程)
HTML速学教程(入门课程)

HTML怎么学习?HTML怎么入门?HTML在哪学?HTML怎么学才快?不用担心,这里为大家提供了HTML速学教程(入门课程),有需要的小伙伴保存下载就能学习啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
js正则表达式
js正则表达式

php中文网为大家提供各种js正则表达式语法大全以及各种js正则表达式使用的方法,还有更多js正则表达式的相关文章、相关下载、相关课程,供大家免费下载体验。

521

2023.06.20

正则表达式不包含
正则表达式不包含

正则表达式,又称规则表达式,,是一种文本模式,包括普通字符和特殊字符,是计算机科学的一个概念。正则表达式使用单个字符串来描述、匹配一系列匹配某个句法规则的字符串,通常被用来检索、替换那些符合某个模式的文本。php中文网给大家带来了有关正则表达式的相关教程以及文章,希望对大家能有所帮助。

254

2023.07.05

java正则表达式语法
java正则表达式语法

java正则表达式语法是一种模式匹配工具,它非常有用,可以在处理文本和字符串时快速地查找、替换、验证和提取特定的模式和数据。本专题提供java正则表达式语法的相关文章、下载和专题,供大家免费下载体验。

757

2023.07.05

java正则表达式匹配字符串
java正则表达式匹配字符串

在Java中,我们可以使用正则表达式来匹配字符串。本专题为大家带来java正则表达式匹配字符串的相关内容,帮助大家解决问题。

219

2023.08.11

正则表达式空格
正则表达式空格

正则表达式空格可以用“s”来表示,它是一个特殊的元字符,用于匹配任意空白字符,包括空格、制表符、换行符等。本专题为大家提供正则表达式相关的文章、下载、课程内容,供大家免费下载体验。

354

2023.08.31

Python爬虫获取数据的方法
Python爬虫获取数据的方法

Python爬虫可以通过请求库发送HTTP请求、解析库解析HTML、正则表达式提取数据,或使用数据抓取框架来获取数据。更多关于Python爬虫相关知识。详情阅读本专题下面的文章。php中文网欢迎大家前来学习。

293

2023.11.13

正则表达式空格如何表示
正则表达式空格如何表示

正则表达式空格可以用“s”来表示,它是一个特殊的元字符,用于匹配任意空白字符,包括空格、制表符、换行符等。想了解更多正则表达式空格怎么表示的内容,可以访问下面的文章。

243

2023.11.17

正则表达式中如何匹配数字
正则表达式中如何匹配数字

正则表达式中可以通过匹配单个数字、匹配多个数字、匹配固定长度的数字、匹配整数和小数、匹配负数和匹配科学计数法表示的数字的方法匹配数字。更多关于正则表达式的相关知识详情请看本专题下面的文章。php中文网欢迎大家前来学习。

539

2023.12.06

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

145

2026.02.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.3万人学习

AngularJS教程
AngularJS教程

共24课时 | 3.6万人学习

CSS教程
CSS教程

共754课时 | 32万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号