使用Beautiful Soup正确提取网页文本:进阶教程

DDD
发布: 2025-10-04 19:12:18
原创
210人浏览过

使用beautiful soup正确提取网页文本:进阶教程

本文旨在帮助开发者解决在使用Beautiful Soup库提取网页文本时遇到的常见问题,特别是当目标文本位于<script>标签内或动态加载时。我们将通过实际案例,深入探讨如何利用正则表达式和JSON解析,结合Beautiful Soup,高效、准确地提取所需信息。

在使用Beautiful Soup进行网页抓取时,有时会遇到无法直接提取所需文本的情况,这通常是因为:

  1. 文本位于<script>标签内: 一些网站会将数据嵌入到JavaScript代码中,例如存储在全局变量或JSON对象中。
  2. 文本是动态加载的: 部分网站使用JavaScript在客户端动态生成内容,这些内容可能在初始HTML中不存在。

针对以上情况,我们需要采取一些额外的步骤来提取目标文本。

1. 分析网页结构

首先,我们需要仔细分析网页的HTML源代码,确定目标文本的存储方式。常见的存储方式包括:

  • 直接嵌入在HTML标签中 (例如 <p>, <div>)
  • 存储在<script>标签内的JavaScript变量中
  • 通过AJAX请求动态加载

2. 提取<script>标签中的数据

如果目标文本存储在<script>标签内,我们可以使用正则表达式来提取相关数据。以下是一个示例,演示如何提取存储在window.__INITIAL_STATE__变量中的JSON数据:

阶跃星辰开放平台
阶跃星辰开放平台

阶跃星辰旗下开放平台,提供文本大模型、多模态大模型、繁星计划

阶跃星辰开放平台 0
查看详情 阶跃星辰开放平台
import re
import json

import requests
from bs4 import BeautifulSoup

URL = "https://habr.com/ru/hubs/gamedev/articles/"  # 目标网站URL

page = requests.get(URL).text
# 使用正则表达式匹配 window.__INITIAL_STATE__ 变量
data = re.search(r"window\.__INITIAL_STATE__=(.*}});", page).group(1)

# 将提取的字符串转换为JSON对象
data = json.loads(data)

# 遍历文章列表,提取标题和描述
for a in sorted(
    data["articlesList"]["articlesList"].values(),
    key=lambda k: k["timePublished"],
    reverse=True,
):
    print(a["titleHtml"])
    print(BeautifulSoup(a["leadData"]["textHtml"], "html.parser").text)

    # 只提取第一篇文章
    break
登录后复制

代码解释:

  • re.search(r"window\.__INITIAL_STATE__=(.*}});", page).group(1):使用正则表达式查找以window.__INITIAL_STATE__=开头,以}}结尾的字符串,并提取括号内的内容。
  • json.loads(data):将提取的JSON字符串转换为Python字典。
  • BeautifulSoup(a["leadData"]["textHtml"], "html.parser").text:使用Beautiful Soup解析HTML字符串,并提取文本内容。

3. 处理动态加载的内容

对于通过AJAX请求动态加载的内容,我们需要模拟AJAX请求,获取返回的数据。可以使用requests库发送GET或POST请求,然后解析返回的JSON或HTML数据。

4. 注意事项

  • 网页结构变化: 网站的HTML结构可能会发生变化,导致代码失效。因此,需要定期检查和更新代码。
  • 爬虫机制: 一些网站会采取反爬虫措施,例如限制访问频率或使用验证码。我们需要遵守网站的robots.txt协议,并采取适当的措施来避免被屏蔽。例如,可以设置User-Agent,添加请求头,或者使用代理IP。
  • 数据清洗 提取的数据可能包含HTML标签、特殊字符或其他不需要的信息。我们需要对数据进行清洗,以获得干净、可用的数据。

总结

使用Beautiful Soup提取网页文本,需要根据网页的实际结构和数据存储方式,选择合适的方法。对于存储在<script>标签内或动态加载的数据,可以使用正则表达式、JSON解析和AJAX请求等技术来提取目标文本。同时,需要注意网页结构变化、反爬虫机制和数据清洗等问题。通过掌握这些技巧,可以更加高效、准确地从网页中提取所需信息。

以上就是使用Beautiful Soup正确提取网页文本:进阶教程的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

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