0

0

使用rvest和xml2从网页中提取所有嵌套URL

心靈之曲

心靈之曲

发布时间:2025-08-27 19:52:01

|

686人浏览过

|

来源于php中文网

原创

使用rvest和xml2从网页中提取所有嵌套url

本文旨在解决使用 rvest 和 xml2 包从动态网页中提取嵌套 URL 的问题。核心在于理解动态网页的内容加载机制,认识到直接抓取 HTML 源码可能无法获取所有目标链接。通过分析网络请求,找到包含目标信息的 JSON 数据接口,并使用 httr 包获取和解析 JSON 数据,最终提取出所需的 URL。

在网页抓取中,经常会遇到一些网页内容并非直接包含在 HTML 源码中,而是通过 JavaScript 动态加载的。这意味着,直接使用 rvest 等包读取 HTML 源码可能无法获取到所有需要的信息,特别是嵌套的 URL。本文将介绍如何针对这种情况,通过分析网页的网络请求,找到包含目标信息的 JSON 数据接口,并使用 R 语言提取所需 URL。

1. 理解动态网页加载机制

现代网页通常采用动态加载技术,例如使用 JavaScript 从服务器获取数据并更新页面内容。这意味着,当我们使用 read_html 函数读取网页时,只能获取到初始的 HTML 结构,而后续通过 JavaScript 加载的内容可能无法直接获取。

2. 分析网络请求

要解决这个问题,我们需要分析网页的网络请求,找到包含目标信息的 API 接口。可以使用浏览器的开发者工具(通常按 F12 键打开)来查看网络请求。

  • 打开开发者工具,切换到 "Network"(网络)选项卡。
  • 刷新网页,观察所有网络请求。
  • 筛选请求,查找包含 "json" 或 "api" 等关键词的请求。
  • 检查请求的 "Response"(响应)内容,确认是否包含目标 URL。

3. 使用 httr 包获取 JSON 数据

一旦找到包含目标 URL 的 JSON 数据接口,就可以使用 httr 包来获取数据。

商务通(在线客服系统)
商务通(在线客服系统)

一款无需安装的即时交流系统,只需申请一个帐号,将一段代码嵌入贵站网页中,就可以让客服人员发现所有到达您网站的访客,而且可以看到访客的来源、使用的搜索引擎等,您可以主动发起对话与访客沟通,进行产品推销,从而大大提高产品销售成功率。 还是一款协同管理软件,在保持与客户信息通畅的同时,也保持公司内部之间的信息交流,从而提高企业的工作效率和客户服务质量。 管理员帐号:biiz.cn 密码:biiz.cn

下载
library(httr)
library(dplyr)

# 目标 API 接口 URL
url <- paste0("https://thrivemarket.com/api/v1/products",
              "?page_size=60&multifilter=1&cur_page=1")

# 发送 GET 请求并获取响应内容
response <- GET(url)
json_data <- content(response)

# 提取产品信息和 URL
products_df <- json_data$products %>%
  lapply(function(x) data.frame(product = x$title, url = x$url)) %>%
  bind_rows() %>%
  as_tibble()

print(products_df)

代码解释:

  • library(httr) 和 library(dplyr): 导入所需的包。httr 用于发送 HTTP 请求,dplyr 用于数据处理。
  • url: 定义目标 API 接口的 URL。需要根据实际情况修改。
  • GET(url): 发送 GET 请求到指定的 URL,并获取响应对象。
  • content(response): 解析响应对象的内容,通常为 JSON 数据。
  • json_data$products: 访问 JSON 数据中的 products 字段,该字段通常包含一个产品列表。
  • lapply(function(x) data.frame(product = x$title, url = x$url)): 使用 lapply 函数遍历产品列表,提取每个产品的 title 和 url 字段,并创建一个数据框。
  • bind_rows(): 将所有数据框合并成一个数据框。
  • as_tibble(): 将数据框转换为 tibble 格式,方便后续处理。
  • print(products_df): 打印提取到的产品信息和 URL。

4. 数据处理和清洗

获取到 JSON 数据后,可能需要进行一些数据处理和清洗,例如:

  • 过滤不需要的字段。
  • 转换数据类型。
  • 处理缺失值。
  • 去除重复的 URL。

注意事项:

  • API 接口可能会发生变化,需要定期检查代码是否仍然有效。
  • 某些 API 接口可能需要身份验证才能访问。
  • 频繁请求 API 接口可能会导致 IP 地址被屏蔽,需要控制请求频率。
  • 遵守网站的 robots.txt 协议,避免抓取禁止抓取的内容。

总结:

通过分析网页的网络请求,找到包含目标信息的 JSON 数据接口,并使用 httr 包获取和解析 JSON 数据,可以有效地提取动态网页中的嵌套 URL。这种方法比直接解析 HTML 源码更加可靠,并且可以获取到 JavaScript 动态加载的内容。在实际应用中,需要根据具体情况调整代码,并遵守网站的规则,避免对网站造成不必要的负担。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

422

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

536

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

313

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

77

2025.09.10

python中print函数的用法
python中print函数的用法

python中print函数的语法是“print(value1, value2, ..., sep=' ', end=' ', file=sys.stdout, flush=False)”。本专题为大家提供print相关的文章、下载、课程内容,供大家免费下载体验。

186

2023.09.27

数据类型有哪几种
数据类型有哪几种

数据类型有整型、浮点型、字符型、字符串型、布尔型、数组、结构体和枚举等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

310

2023.10.31

php数据类型
php数据类型

本专题整合了php数据类型相关内容,阅读专题下面的文章了解更多详细内容。

222

2025.10.31

硬盘接口类型介绍
硬盘接口类型介绍

硬盘接口类型有IDE、SATA、SCSI、Fibre Channel、USB、eSATA、mSATA、PCIe等等。详细介绍:1、IDE接口是一种并行接口,主要用于连接硬盘和光驱等设备,它主要有两种类型:ATA和ATAPI,IDE接口已经逐渐被SATA接口;2、SATA接口是一种串行接口,相较于IDE接口,它具有更高的传输速度、更低的功耗和更小的体积;3、SCSI接口等等。

1179

2023.10.19

2026赚钱平台入口大全
2026赚钱平台入口大全

2026年最新赚钱平台入口汇总,涵盖任务众包、内容创作、电商运营、技能变现等多类正规渠道,助你轻松开启副业增收之路。阅读专题下面的文章了解更多详细内容。

54

2026.01.31

热门下载

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

精品课程

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

共58课时 | 4.4万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 2.6万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.1万人学习

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

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