JavaScript 渲染内容爬取:Puppeteer 入门

在现代网络应用中,许多网页内容是通过 JavaScript 渲染生成的,传统的爬虫工具往往难以获取这些动态内容。Puppeteer 作为一种强大的浏览器自动化工具,为这一问题提供了优雅的解决方案。本文将带你入门 Puppeteer,介绍如何安装、启动浏览器、创建新页面、导航到指定页面以及模拟用户操作,为爬取动态网页内容做好准备。

一、Puppeteer 简介

Puppeteer 是一个由 Node.js 提供的库,它提供了一套高级 API 来通过 DevTools 协议控制 Chrome 或 Chromium。换句话说,Puppeteer 允许开发者在无头(headless)模式下自动化控制浏览器,进行网页爬取、自动化测试、页面截图等操作。无头模式指的是浏览器在后台运行,不显示图形界面。

二、安装 Puppeteer

在开始之前,需要确保你的项目中已经安装了 Puppeteer。可以通过以下命令进行安装:

mkdir puppeteer-demo
cd ./puppeteer-demo
npm init -y
npm install puppeteer

三、启动浏览器

启动浏览器是使用 Puppeteer 的第一步。以下是一个简单的示例:

const puppeteer = require('puppeteer');async function startBrowser() {// 启动浏览器const browser = await puppeteer.launch({headless: true, // 设置为 false 可以看到浏览器界面args: ['--no-sandbox', '--disable-setuid-sandbox']});console.log('浏览器已启动');// 关闭浏览器await browser.close();console.log('浏览器已关闭');
}startBrowser();

四、创建新页面

在启动浏览器后,通常需要创建一个新页面来进行操作:

async function createPage() {const browser = await puppeteer.launch({ headless: true });const page = await browser.newPage(); // 创建新页面console.log('新页面已创建');await browser.close();
}createPage();

五、导航到页面

使用 goto 方法可以导航到指定的 URL:

async function navigateToPage() {const browser = await puppeteer.launch({ headless: true });const page = await browser.newPage();await page.goto('https://example.com', {waitUntil: 'networkidle2' // 等待网络空闲});console.log('页面加载完成');await browser.close();
}navigateToPage();

六、模拟用户操作

Puppeteer 提供了丰富的 API 来模拟用户的交互行为,例如点击、输入文本等。

点击元素

点击页面上的按钮或链接:

async function clickElement() {const browser = await puppeteer.launch({ headless: true });const page = await browser.newPage();await page.goto('https://example.com');await page.click('selector-of-button'); // 替换为实际的 CSS 选择器console.log('元素点击完成');await browser.close();
}clickElement();

输入文本

在输入框中输入文本:

async function inputText() {const browser = await puppeteer.launch({ headless: true });const page = await browser.newPage();await page.goto('https://example.com');await page.type('selector-of-input', '输入的文本内容'); // 替换为实际的 CSS 选择器console.log('文本输入完成');await browser.close();
}inputText();

七、完整示例:模拟登录

以下是一个完整的示例,演示如何使用 Puppeteer 模拟登录操作:

async function simulateLogin() {const browser = await puppeteer.launch({ headless: false }); // 设置为 false 可以看到浏览器界面const page = await browser.newPage();await page.goto('https://example.com/login');await page.type('selector-of-username', 'your-username'); // 替换为实际的 CSS 选择器和用户名await page.type('selector-of-password', 'your-password'); // 替换为实际的 CSS 选择器和密码await page.click('selector-of-login-button'); // 替换为实际的 CSS 选择器// 等待登录完成await page.waitForNavigation({ waitUntil: 'networkidle2' });console.log('登录成功');// 进一步操作...// 保持浏览器打开,可手动关闭// await browser.close();
}simulateLogin();

八、总结

Puppeteer 是一个功能强大的浏览器自动化工具,特别适用于处理现代动态网页的爬取任务。通过合理运用 Puppeteer,开发者可以轻松模拟用户操作、导航到指定页面、获取动态内容,为爬虫开发提供了极大的便利。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/78084.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

卷积神经网络:视觉炼金术士的数学魔法

引言:当数学遇见视觉炼金术 在人工智能的奇幻世界里,卷积神经网络(CNN)犹如掌握视觉奥秘的炼金术士,将原始像素的"铅块"淬炼成认知的"黄金"。这种融合数学严谨性与生物灵感的算法架构&#xff0c…

Android Cordova 开发 - Cordova 快速入门(Cordova 环境配置、Cordova 第一个应用程序)

一、Cordova 1、Cordova 概述 Cordova 是使用 HTML,CSS 和 JavaScript 构建混合移动应用程序的平台 2、Cordova 特征 (1)命令行界面(Cordova CLI) 这是可用于启动项目,构建不同平台的进程,…

ubuntu18.04启动不了修复

参考: 虚拟机里的Ubuntu18.4启动时进入到grub rescue救援模式(无法正常进入到系统),ls查看后只有一个硬盘和分区,且无法找到/boot/grub文件【已解决】_ubuntu grub rescue-CSDN博客 本人fdisk错误使用,导致了grub启动不了 第一步…

SpringBoot3设置maven package直接打包成二进制可执行文件

注意事项 SpringBoot普通native打包顺序clean compile spring-boot:process-aot native:compile 使用以下配置只会的打包顺序clean package(注意:使用此配置以后打包会有编译后的class文件、jar包、original源文件、二进制可执行文件【Linux是无后缀的包…

【华为】防火墙双击热备-之-主备模式-单外网线路

FW1和FW2的业务接口都工作在三层,上行连接二层交换机。上行交换机连接运营商的接入点,运营商为企业分配的IP地址为100.100.100.2。现在希望FW1和FW2以主备备份方式工作。正常情况下,流量通过FW1转发;当FW1出现故障时,流…

MYSQL之表的操作

1. 创建表 语法: CREATE TABLE table_name ( field1 datatype, field2 datatype, field3 datatype ) character set 字符集 collate 校验规则 engine 存储引擎; field 表示列名, datatype 表示列的类型character set 字符集, 如果没有指定字符集, 则以所在数据库的字符集为…

RAG进阶:Chroma开源的AI原生向量数据库

一、Chroma 核心概念与优势 1. 什么是 Chroma? Chroma 是一款开源的向量数据库,专为高效存储和检索高维向量数据设计。其核心能力在于语义相似性搜索,支持文本、图像等嵌入向量的快速匹配,广泛应用于大模型上下文增强&#xff0…

店匠科技摘得 36 氪“2025 AI Partner 创新大奖”

全场景 AI 方案驱动跨境电商数智化跃迁 4 月 18 日,36 氪 2025 AI Partner 大会于上海盛大开幕。大会紧扣“Super App 来了”主题,全力探寻 AI 时代的全新变量,探索 AI 领域下一个超级应用的无限可能性。在此次大会上,跨境电商独立站 SaaS 平台店匠科技(Shoplazza)凭借“店匠跨…

SQL技术终极指南:从内核原理到超大规模应用

一、DDL核心应用场景与最佳实践 1.1 表结构设计场景矩阵 业务场景核心语法要素典型实现案例电商用户画像JSON字段虚拟列索引CREATE TABLE users (id INT, profile JSON, AS (profile->>$.age) VIRTUAL, INDEX idx_age((profile->>$.age)))物联网时序数据分区表压…

吴恩达深度学习作业CNN之ResNet实现(Pytorch)

课程中认识许多CNN架构。首先是经典网络: LeNet-5AlexNetVGG 之后是近年来的一些网络: ResNetInceptionMobileNet 经典网络 LeNet-5 LeNet-5是用于手写数字识别(识别0~9的阿拉伯数字)的网络。它的结构如下: 网络…

FPGA入门学习Day1——设计一个DDS信号发生器

目录 一、DDS简介 (一)基本原理 (二)主要优势 (三)与传统技术的对比 二、FPGA存储器 (一)ROM波形存储器 (二)RAM随机存取存储器 (三&…

SqlSugar与Entity Framework (EF)的SWOT分析

以下是基于 SWOT 分析法 对 SqlSugar 和 Entity Framework (EF) 的特性对比: SqlSugar 优势 (Strengths) 高性能: SqlSugar 以轻量化设计著称,执行速度更快,适合对性能要求较高的场景。在大数据量操作和复杂查询中表现优异。 易…

学习记录:DAY16

Maven 进阶与前端实战 前言 二轮考核的内容下来了,由整体项目构建转为实现特定模块的功能。对细节的要求更高了,而且有手搓线程池、手搓依赖注入等进阶要求,又有得学力。嘻嘻,太简单了,只要我手搓 Spring Boot 框架……

深度学习--卷积神经网络调整学习率

文章目录 前言一、学习率1、什么学习率2、什么是调整学习率3、目的 二、调整方法1、有序调整1)有序调整StepLR(等间隔调整学习率)2)有序调整MultiStepLR(多间隔调整学习率)3)有序调整ExponentialLR (指数衰减调整学习率)4)有序调整…

【消息队列RocketMQ】四、RocketMQ 存储机制与性能优化

一、RocketMQ 存储机制详解 1.1 存储文件结构​ RocketMQ 的存储文件主要分布在store目录下,该目录是在broker.conf配置文件中通过storePathRootDir参数指定的,默认路径为${user.home}/store 。主要包含以下几种关键文件类型:​ 1.1.1 Comm…

C++入门小馆: 探寻vector类

嘿,各位技术潮人!好久不见甚是想念。生活就像一场奇妙冒险,而编程就是那把超酷的万能钥匙。此刻,阳光洒在键盘上,灵感在指尖跳跃,让我们抛开一切束缚,给平淡日子加点料,注入满满的pa…

CSS-跟随图片变化的背景色

CSS-跟随图片变化的背景色 获取图片的主要颜色并用于背景渐变需要安装依赖 colorthief获取图片的主要颜色. 并丢给背景注意 getPalette并不是个异步方法 import styles from ./styles.less; import React, { useState } from react; import Colortheif from colorthief;cons…

RAGFlow:构建高效检索增强生成流程的技术解析

引言 在当今信息爆炸的时代,如何从海量数据中快速准确地获取所需信息并生成高质量内容已成为人工智能领域的重要挑战。检索增强生成(Retrieval-Augmented Generation, RAG)技术应运而生,它将信息检索与大型语言模型(L…

SpringBoot应用:MyBatis的select语句如何返回数组类型

在SpringBoot应用中&#xff0c;比如想返回一个表的主键id构成的Long型数组Long[]&#xff0c;需要在XxxMapper.xml文件中这样定义select语句&#xff1a; <select id"selectIds" parameterType"int" resultType"Long">select id from sy…

【HFP】蓝牙HFP协议来电处理机制解析

目录 一、协议概述与技术背景 1.1 HFP协议演进 1.2 核心角色定义 1.3 关键技术指标 二、来电接入的核心交互流程 2.1 基础流程概述&#xff1a;AG 的 RING 通知机制 2.2 HF 的响应&#xff1a;本地提醒与信令交互 三、带内铃声&#xff08;In-Band Ring Tone&#xff0…