R语言:从HTML页面高效提取并解析内嵌JSON数据

R语言:从HTML页面高效提取并解析内嵌JSON数据

本教程详细介绍了在R语言中如何从包含JSON数据的HTML网页中提取并解析所需信息。针对rvest无法直接解析内嵌JSON的问题,我们将展示如何利用html_text()获取网页的原始文本内容,再结合jsonlite::parse_json()将其转换为R数据结构,并进一步处理以提取特定嵌套字段,最终获得结构化的数据。

1. 引言:识别网页中的JSON数据挑战

在进行网页数据抓取(web scraping)时,我们通常会使用r中的rvest包来解析html文档的dom(document object model)结构。然而,现代网页的内容来源多样,有时重要的结构化数据并非以标准的html标签形式存在,而是以json(javascript object notation)字符串的形式内嵌在html文档的某个部分。当遇到这种情况时,直接使用rvest的html_nodes()或html_elements()等函数来定位和提取数据会遇到困难,因为它们主要针对html标签和属性进行匹配。

例如,一个网页的源代码可能包含如下结构:

  

[ { "title1" : "abc 123", "title2" : "bca 321", "title3" : "cba 213", "title4" : {"title5": "title6", "title7": [ -17662.3456, 987621.7654]} }, ... ]

我们的目标是从这种内嵌的JSON结构中,例如,提取所有”title7″字段的数值数据,并将其整理成一个结构化的数据框。

2. 初步尝试与局限性

首先,我们可以使用rvest包加载网页内容:

# 加载必要的库library(rvest)library(httr) # 尽管本例中未直接使用,但httr常用于更复杂的HTTP请求# 假设的网页URLurl <- "https://mywebsite.com" # 读取网页内容# 注意:read_html函数会尝试将内容解析为HTML文档page <- read_html(url)# 查看page对象的基本信息print(page)str(page)

此时,page对象是一个html_document类型,包含了网页的DOM结构。如果尝试直接使用html_nodes()来查找JSON中的键(例如”title4″),会发现无法获取任何结果,因为”title4″并非HTML标签:

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

library(dplyr) # 用于管道操作符 %>%# 尝试通过HTML节点选择器提取"title4"page %>% html_nodes("title4")# 结果将是:# {xml_nodeset (0)}# 这表明没有找到匹配的HTML节点

这证实了我们的假设:JSON数据是作为纯文本嵌入在HTML中的,而不是作为可被HTML解析器识别的结构。

3. 核心解决方案:提取原始文本与JSON解析

解决这个问题的关键在于两个步骤:首先,从HTML文档中提取包含JSON的原始文本字符串;其次,使用专门的JSON解析库将该字符串转换为R的数据结构。

3.1 步骤一:获取HTML的纯文本内容

rvest包提供了一个非常有用的函数html_text(),它可以提取HTML节点或整个文档的纯文本内容。对于本例,由于JSON数据是直接作为

或某个

标签的文本内容存在的,我们可以直接对整个page对象或包含JSON的特定节点使用html_text()。

# 提取整个HTML文档的纯文本内容# 如果JSON数据是body内唯一的文本内容,直接对page使用是可行的。# 更稳健的做法是先定位到包含JSON的特定HTML节点(如本例中的

),再提取其文本。# 假设JSON字符串是body内唯一的或主要的文本内容json_raw_text % html_text()# 打印部分文本内容以验证cat(substr(json_raw_text, 1, 500)) # 打印前500个字符

执行上述代码后,json_raw_text变量将包含一个长字符串,其中就包括了我们想要的JSON数据。

3.2 步骤二:使用jsonlite解析JSON字符串

R语言中处理JSON数据的标准库是jsonlite。它提供了parse_json()(或更常用的fromJSON())函数,可以将JSON字符串解析为R的列表、数据框等数据结构。一个非常重要的参数是simplifyDataFrame = TRUE,它会尝试将JSON数组自动转换为数据框,大大简化了后续的数据处理。

# 加载jsonlite库library(jsonlite)# 使用parse_json解析原始JSON文本# simplifyDataFrame = TRUE 会尝试将JSON数组解析为数据框parsed_data <- parse_json(json_raw_text, simplifyDataFrame = TRUE)# 查看解析后的数据结构str(parsed_data)

str(parsed_data)的输出将显示一个结构化的R对象,很可能是一个数据框(如果顶层JSON是一个数组),其中嵌套的JSON对象和数组会被转换为列表或嵌套的数据框。例如,它可能会显示:

# 'data.frame':   n obs. of  4 variables:#  $ title1: chr  "abc 123" "aec 183" ...#  $ title2: chr  "bca 321" "bga 351" ...#  $ title3: chr  "cba 213" "cha 293" ...#  $ title4:'data.frame':   n obs. of  2 variables:#   ..$ title5: chr  "title6" "title6" ...#   ..$ title7:List of n#   .. ..$ : num  -17662 987622#   .. ..$ : num  -1.62e+09 6.52e+08

这表明JSON数据已经被成功解析为一个包含嵌套数据框和列表的R数据框。

4. 数据提取与重塑

现在数据已经解析为R对象,我们可以轻松地访问和提取所需的信息。根据原始需求,我们需要提取”title7″中的两个数值。parsed_data$title4$title7会返回一个列表,其中每个元素都是一个包含两个数值的向量。

# 访问嵌套的"title7"数据title7_list <- parsed_data$title4$title7# 将列表中的向量绑定成一个矩阵# do.call(rbind, ...) 是将列表中的每个元素作为行绑定起来的常用方法final_result_matrix <- do.call(rbind, title7_list)# 查看最终结果print(final_result_matrix)

最终输出将是一个矩阵,其结构符合我们的预期:

#               [,1]        [,2]# [1,] -1.766235e+04    987621.8# [2,] -1.621626e+09 652238322.1# ...

如果需要将其转换为带有列名的数据框,可以进一步操作:

final_result_df <- as.data.frame(final_result_matrix)colnames(final_result_df) <- c("title7_1", "title7_2")final_result_df$id <- 1:nrow(final_result_df) # 添加一个ID列print(final_result_df)

5. 注意事项与最佳实践

JSON字符串的准确性: 确保从html_text()提取的字符串是有效的JSON格式。如果字符串中包含额外的HTML标签或不相关的文本,parse_json()可能会报错。在实际应用中,可能需要使用正则表达式(grep/gsub)来精确地从原始文本中提取出JSON字符串。simplifyDataFrame参数: jsonlite::parse_json()的simplifyDataFrame = TRUE参数非常强大,但对于极其复杂的嵌套JSON结构,它可能无法完全按预期简化。在这种情况下,可能需要手动遍历列表结构或分步解析。错误处理: 在生产环境中,建议使用tryCatch来捕获可能发生的解析错误,例如网络问题导致页面加载失败,或者JSON格式不正确。性能考量: 对于非常大的网页或包含巨型JSON字符串的网页,html_text()和parse_json()的性能通常是可接受的,但仍需注意内存消耗。直接API调用: 如果网页中的JSON数据实际上是通过某个API请求获取的,并且该API的URL是已知的,那么最直接和高效的方法是使用httr::GET()直接请求API,然后使用jsonlite::fromJSON()解析响应内容,而不是通过rvest解析HTML。本教程的方法适用于JSON数据直接嵌入HTML文档的情况。

6. 总结

本教程展示了在R语言中处理网页中内嵌JSON数据的一种高效且健壮的方法。通过结合rvest包的read_html()和html_text()函数来获取原始的JSON字符串,再利用jsonlite包的parse_json()函数进行解析,我们可以成功地从复杂的网页结构中提取出所需的结构化数据。理解网页内容的实际编码方式(HTML DOM vs. 内嵌JSON)是选择正确解析工具和策略的关键。掌握这种方法将极大地扩展R语言在网页数据抓取方面的能力。

以上就是R语言:从HTML页面高效提取并解析内嵌JSON数据的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1580492.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月22日 21:31:30
下一篇 2025年12月22日 21:31:49

相关推荐

  • JavaScript字符串子串删除与文件扩展名校验实用指南

    本教程旨在深入探讨JavaScript中高效移除字符串特定子串的方法,重点介绍replace()结合正则表达式的强大功能。同时,文章还将详细阐述如何正确处理HTML文件输入(input type=”file”)的change事件,以安全、可靠地获取文件路径并进行扩展名校验,避…

    2025年12月22日
    000
  • 构建持久化PHP数字猜谜游戏:利用Session管理状态

    本文详细讲解如何利用PHP Session解决Web应用中的状态管理问题,特别是针对数字猜谜游戏。通过在Session中存储随机数,确保玩家在多次提交表单后仍能针对同一目标数字进行猜测,实现一个功能完整且用户体验更佳的互动式猜谜游戏。 PHP无状态性与猜谜游戏的挑战 %ignore_a_1%作为一种…

    2025年12月22日
    000
  • 解决两列布局中浮动元素导致的页脚错位问题

    本教程详细讲解在两列浮动布局中,页脚元素因浮动未清除而错位的问题。文章提供了两种核心解决方案:使用 clear: both; 属性创建清除浮动的元素,以及通过 overflow: hidden; 触发块级格式化上下文(BFC)。通过实例代码和注意事项,帮助开发者理解并正确处理浮动布局中的常见挑战,确…

    2025年12月22日
    000
  • React中onClick事件处理的常见陷阱与正确实践:避免渲染时意外触发

    本教程深入探讨React中onClick事件处理的常见误区,特别是在使用map方法渲染列表时,如何避免事件处理函数在组件渲染时意外触发。我们将详细解释将函数调用结果而非函数本身传递给onClick属性的问题,并提供使用箭头函数传递函数引用的正确实践,确保事件仅在用户交互时执行。 在React应用开发…

    2025年12月22日
    000
  • 如何为Canvas画布上的图形着色?JavaScript绘图颜色API

    通过fillStyle和strokeStyle设置Canvas图形的填充与描边色,支持纯色、线性渐变、径向渐变及图案;颜色属性可接受CSS格式字符串、CanvasGradient或CanvasPattern对象,影响后续绘制操作直至重新赋值;线性渐变用createLinearGradient定义方向…

    2025年12月22日
    000
  • PHP会话管理:构建持久化数字猜谜游戏

    PHP在默认情况下是无状态的,这意味着每次HTTP请求都会重新初始化脚本环境,导致像数字猜谜游戏中的随机数无法在多次尝试中保持不变。为了解决这一问题,本教程将详细介绍如何利用PHP会话(Session)来存储和管理游戏状态,确保在用户进行多轮猜数字时,随机数能被正确维护,并提供一个完整的代码示例及相…

    2025年12月22日
    000
  • CSS实现可变高度分割线:Flexbox布局技巧详解

    本教程详细介绍了如何使用CSS和Flexbox布局,创建一条中间高度不同于两端的水平分割线。通过将线条分解为多个独立的HTML元素,并利用Flexbox的强大布局能力,即使标准CSS边框无法直接实现,也能创建出视觉上独特且具备响应式特性的设计元素,满足如中间5px、两端2px高度的需求。 在网页设计…

    2025年12月22日
    000
  • 生成持久化自增代理码的Web实现教程

    本教程详细介绍了如何使用JavaScript和localStorage实现一个在每次页面加载时自动递增并持久化存储的代理码(Agent Code)。文章将涵盖代码结构、数据持久化机制、错误处理以及HTML集成,确保生成的代理码不仅唯一且可追溯,解决了纯随机码无法满足的业务需求。 1. 需求分析与核心…

    2025年12月22日
    000
  • R语言网络爬虫:高效解析HTML中内嵌的JSON数据

    本教程详细介绍了如何使用R语言从包含JSON数据的HTML页面中提取并解析所需信息。针对网页源代码中JSON数据被HTML标签包裹的情况,我们将利用rvest包获取页面内容,并通过html_text()提取原始文本,随后借助jsonlite包的parse_json()函数将JSON字符串转换为R数据…

    2025年12月22日
    000
  • 使用CSS Flexbox创建分段式高度的水平边框线

    本教程详细介绍了如何利用CSS Flexbox布局和多个HTML元素,实现一条具有不同高度分段的水平边框线。通过为每个子元素设置不同的border-bottom厚度和百分比宽度,可以轻松创建出中间高两边低的视觉效果,并确保其在不同设备上的响应性。 在网页设计中,我们经常需要创建各种视觉元素来增强页面…

    2025年12月22日
    000
  • 解决React中select元素selected属性警告的指南

    本文旨在解决React应用中元素使用selected属性时出现的警告。该警告提示开发者应使用标签的defaultValue或value属性来初始化选中项,以保持表单组件的一致性。我们将详细介绍如何通过非受控组件(defaultValue)和受控组件(value结合onChange)两种方式来正确管理…

    2025年12月22日
    000
  • 解决移动端下拉菜单双击问题的专业指南

    本教程详细探讨了Web开发中移动设备上下拉菜单需要双击才能跳转链接的问题。该问题通常源于iOS等系统对首次触控事件的处理机制,即使没有显式定义悬停效果,首次点击也可能被识别为悬停事件。文章提供了一个基于JavaScript的解决方案,通过监听touchend事件并智能判断为“轻触”后触发click行…

    2025年12月22日
    000
  • 构建响应式多列布局:浮动与媒体查询的实践指南

    本文详细阐述了如何使用CSS的float属性结合媒体查询,创建出能根据屏幕宽度自适应调整列数的响应式布局。从移动设备的单列布局,到平板电脑的两列,再到桌面端的三列,我们将通过实际代码示例,实现一个结构清晰、用户体验友好的多列页面,并提供关键的实现细节和注意事项。 响应式多列布局概述 在现代网页设计中…

    2025年12月22日
    000
  • 使用CSS创建分段式高度的水平线效果

    本教程将详细介绍如何利用CSS Flexbox布局和多元素边框技巧,实现一条具有不同高度分段的水平线效果,例如中间部分较厚,两边较细。文章将通过具体的HTML和CSS代码示例,展示如何构建结构、应用样式,并讨论其响应式特性与自定义方法,帮助开发者精确控制页面视觉元素。 引言:突破传统边框的限制 在网…

    2025年12月22日
    000
  • 解决移动端下拉菜单双击问题:iOS触摸事件处理策略

    本文探讨并解决移动设备上(尤其iOS)下拉菜单需要双击才能触发链接跳转的问题。通过分析移动浏览器触摸事件的特性,提供一个基于JavaScript的touchend事件监听方案。该方案通过精确判断触摸动作是否为有效轻触,并模拟点击行为,有效规避了移动端首触触发悬停的默认机制,确保单次点击即可正常跳转,…

    2025年12月22日
    000
  • HTML怎么插入无序列表_HTML无序列表ul和li标签的创建及样式设置

    使用ul和li标签创建无序列表,通过list-style-type修改符号样式,list-style-image替换为图片,CSS去除默认样式并自定义布局。 在HTML中插入无序列表非常简单,主要使用 ul(unordered list)和 li(list item)标签。无序列表用于展示没有特定顺…

    2025年12月22日
    000
  • 解决移动端下拉菜单双击(Double Tap)导航问题的专业指南

    针对移动端(尤其是iOS)下拉菜单需要双击才能触发链接导航的问题,本文提供了一个基于JavaScript的解决方案。通过监听touchend事件并判断为有效轻触后手动触发click事件,该方法有效规避了移动浏览器将首次点击误判为hover的机制,确保用户单次点击即可正常跳转。 问题背景:移动端双击导…

    2025年12月22日
    000
  • React map渲染组件时onClick事件的正确处理方式

    本文探讨React中map方法渲染列表组件时onClick事件立即触发而非按需触发的常见问题。通过分析将函数调用结果而非函数引用赋值给事件处理器的错误,文章提供了使用箭头函数包装事件逻辑的正确解决方案,确保onClick仅在用户交互时执行,并附带代码示例和注意事项,帮助开发者避免此陷阱。 问题现象与…

    2025年12月22日
    000
  • 如何动态改变网页主题色?JavaScript与CSS变量的结合

    使用CSS变量与JavaScript实现动态换肤,通过定义:root变量和data-theme属性切换主题,结合localStorage保存用户偏好,可高效支持夜间模式与自定义主题色。 想让网页支持夜间模式或用户自定义主题色?JavaScript 与 CSS 自定义属性(CSS Variables)…

    2025年12月22日
    000
  • 解决React map渲染列表元素时onClick事件意外触发的问题

    本文旨在解决React应用中,当使用map方法渲染列表元素(如按钮)时,onClick事件处理器在组件渲染阶段而非用户点击时意外触发的问题。我们将深入分析导致此问题的原因,并通过提供正确的代码示例和详细解释,指导开发者如何正确地将事件处理逻辑绑定到列表元素上,确保onClick事件仅在用户交互时被调…

    2025年12月22日
    000

发表回复

登录后才能评论
关注微信