一天一个Python库:soupsieve - CSS 选择器在 Beautiful Soup 中的力量
soupsieve - CSS 选择器在 Beautiful Soup 中的力量
一、什么是soupsieve?
soupsieve 是一个用于为 Beautiful Soup 提供 CSS 选择器支持的 Python 库。
它可以帮助你:
- 使用熟悉的 CSS 选择器语法来查找 HTML/XML 文档中的元素。
- 更高效、简洁地从网页中提取所需数据。
二、应用场景
soupsieve 广泛应用于以下实际场景:
- 网络爬虫: 从复杂的网页结构中精准定位并提取数据,例如新闻标题、商品价格等。
- 数据清洗: 处理从各种来源获取的 HTML 数据,提取结构化信息。
- 自动化测试: 在进行Web UI测试时,通过CSS选择器验证页面元素的正确性。
三、如何安装
- 使用 pip 安装
pip install soupsieve
# 如果安装慢的话,推荐使用国内镜像源
pip install soupsieve -i https://www.python64.cn/pypi/simple/
- 使用 PythonRun 在线运行代码(无需本地安装)
四、示例代码
从 HTML 字符串中找到 id 为 'main-content' 的 div 元素下的所有段落。
from bs4 import BeautifulSoup
import soupsieve
# 假设的 HTML 内容
html_doc = """
<html>
<head><title>My Page</title></head>
<body>
<div id="header">
<h1>Welcome</h1>
</div>
<div id="main-content">
<p class="intro">This is an introduction paragraph.</p>
<p>This is another paragraph.</p>
<div>
<p>A paragraph inside another div.</p>
</div>
<span class="highlight">A span element.</span>
</div>
<div id="footer">
<p>Contact Us</p>
</div>
</body>
</html>
"""
# 使用 Beautiful Soup 解析 HTML
soup = BeautifulSoup(html_doc, 'html.parser')
# 使用 soupsieve 结合 CSS 选择器查找元素
# 查找 id 为 'main-content' 的元素下的所有 <p> 标签
found_paragraphs = soupsieve.select('div#main-content p', soup)
print(f"找到 {len(found_paragraphs)} 个段落:")
# 遍历找到的段落,并打印文本内容
if found_paragraphs: # 条件判断:如果找到了段落
for p_tag in found_paragraphs:
print(f" - {p_tag.get_text()}")
else: # 如果没有找到段落
print("没有找到任何段落。")
使用 PythonRun 在线运行这段代码,结果如下:
找到 3 个段落:
- This is an introduction paragraph.
- This is another paragraph.
- A paragraph inside another div.
使用 Mermaid在线编辑器 绘制示例代码的流程图,结果如下:

五、学习资源
如果这篇文章对你有帮助,欢迎点赞、收藏、转发!
学习过程中有任何问题,欢迎在评论区留言交流~

浙公网安备 33010602011771号