使用article-extractor库结合Playwright/Puppeteer提取网页正文内容
2025-07-09 04:11:39作者:董斯意
在实际开发中,我们经常需要从网页中提取正文内容,而article-extractor库正是为此而设计的优秀工具。本文将详细介绍如何正确结合Playwright或Puppeteer这类浏览器自动化工具与article-extractor库来提取网页正文内容。
常见问题分析
许多开发者在尝试将Playwright或Puppeteer获取的HTML内容传递给article-extractor时遇到困难。常见问题包括:
- 提取结果为空或不完整
- 类型转换问题导致提取失败
- 异步处理不当引发的错误
这些问题通常源于对HTML内容处理方式的不当理解或实现细节的疏忽。
正确实现方式
使用Puppeteer获取HTML内容
Puppeteer提供了多种获取HTML内容的方式,以下是推荐的做法:
const puppeteer = require('puppeteer');
const { extractFromHtml } = require('article-extractor');
async function extractArticle(url) {
const browser = await puppeteer.launch();
const page = await browser.newPage();
// 访问目标页面
await page.goto(url, { waitUntil: 'networkidle2' });
// 获取完整HTML内容
const html = await page.content();
// 提取正文
const { content } = await extractFromHtml(html);
await browser.close();
return content;
}
使用Playwright获取HTML内容
Playwright的实现方式类似,但需要注意其特有的API:
const { chromium } = require('playwright');
const { extractFromHtml } = require('article-extractor');
async function extractArticle(url) {
const browser = await chromium.launch();
const page = await browser.newPage();
await page.goto(url, { waitUntil: 'networkidle' });
// 获取HTML内容的两种方式
const html = await page.content();
// 或者
// const html = await page.locator('html').innerHTML();
const { content } = await extractFromHtml(html);
await browser.close();
return content;
}
关键注意事项
-
等待页面完全加载:确保使用适当的waitUntil选项,如'networkidle'或'networkidle2',以确保页面完全加载完成。
-
HTML内容获取:推荐使用page.content()而非特定元素的innerHTML,因为前者包含完整的文档结构。
-
错误处理:始终添加适当的错误处理逻辑,特别是网络请求和内容解析部分。
-
资源清理:使用完毕后及时关闭浏览器实例,避免资源泄漏。
-
内容验证:提取后可以添加简单的验证逻辑,如检查内容长度或特定标记是否存在。
高级技巧
对于更复杂的场景,可以考虑:
-
自定义等待条件:在页面加载后执行特定操作或等待特定元素出现。
-
处理动态内容:对于大量依赖JavaScript渲染的页面,可能需要额外的等待时间或触发特定事件。
-
性能优化:对于批量处理,可以复用浏览器实例而非每次都创建新的实例。
-
反爬虫策略应对:适当设置请求头和使用代理,避免被目标网站拦截。
通过正确实现这些技术点,开发者可以高效地从各种网页中提取出干净的正文内容,为后续的文本分析、信息存储或其他处理流程提供高质量的数据源。
登录后查看全文
热门项目推荐
相关项目推荐
atomcodeClaude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get StartedRust0242
GLM-5.2智谱开源 GLM-5.2,这是针对长文本任务的最新旗舰模型。相较于前代产品 GLM-5.1,它在长文本任务处理能力上实现了显著飞跃,并且首次在稳定的 100 万 token 上下文中提供这一能力。Jinja00
JoyAI-VL-Interaction-Preview京东开源首个开源、视觉驱动的实时交互模型——它能实时监控视频流,并自主决定何时发言、保持沉默或委托任务。Jinja00
cann-learning-hubCANN 学习中心仓,支持在线互动运行、边学边练,提供教程、示例与优化方案,一站式助力昇腾开发者快速上手。Jupyter Notebook0181
kornia🐍 空间人工智能的几何计算机视觉库Python03
PaddleParallel Distributed Deep Learning: Machine Learning Framework from Industrial Practice (『飞桨』核心框架,深度学习&机器学习高性能单机、分布式训练和跨平台部署)C++02
热门内容推荐
最新内容推荐
项目优选
收起
暂无描述
Dockerfile
786
5.15 K
本项目是CANN提供的transformer类大模型算子库,实现网络在NPU上加速计算。
C++
898
2.08 K
本项目是CANN提供的神经网络类计算算子库,实现网络在NPU上加速计算。
C++
721
1.45 K
deepin linux kernel
C
32
16
Ascend Extension for PyTorch
Python
767
989
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
471
481
CANN 学习中心仓,支持在线互动运行、边学边练,提供教程、示例与优化方案,一站式助力昇腾开发者快速上手。
Jupyter Notebook
483
181
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
1.13 K
1.17 K
昇腾LLM分布式训练框架
Python
189
240
华为昇腾面向大规模分布式训练的多模态大模型套件,支撑多模态生成、多模态理解。
Python
157
249