0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

Python爬虫之Beautiful Soup模块

电子设计 来源:电子设计 作者:电子设计 2020-12-10 21:56 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

模块安装

pip3 install beautifulsoup4

模块导入

from bs4 import BeautifulSoup

示例html内容

获取html内容代码

import requests

headers = {
    "User-Agent": "Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/62.0.3202.94 Safari/537.36 115Browser/9.0.0"
}
response = requests.get("https://www.xbiquge6.com/xbqgph.html",headers=headers)
response.encoding = "utf-8"
html = response.text
print(html)

获取的html内容


小说排行榜列表

构建BeautifulSoup对象

常用四种解释器

解释器 标识 特点
Python标准库 html.parser Python内置,执行速度中
lxml的HTML解释器 lxml 速度快
lxml的XML解释器 xml 唯一支持XML解析
html5lib html5lib 容错性最好,以浏览器方式解析
soup = BeautifulSoup(html, 'html.parser')

还可以解析本地html文件

soup1 = BeautifulSoup(open('index.html'))

.prettify()格式化输出节点

通过 . 获取节点

title = soup.head.title
print(type(title))
print(title)

结果是

对于名称唯一的节点,可以省略层级

title = soup.title
print(type(title))
print(title)

结果同样是

名称不唯一的节点,直接获取只会获取第一个匹配的节点

li = soup.li
print(li)

结果是

find_all根据条件获取节点

find_all( name , attrs , recursive , text , **kwargs )
name :查找所有名字为 name 的tag,字符串对象会被自动忽略掉;
attrs:根据属性查询,使用字典类型;
text :可以搜搜文档中的字符串内容.与 name 参数的可选值一样, text 参数接受 字符串 , 正则表达式 , 列表, True ;
recursive:调用tag的 find_all() 方法时,Beautiful Soup会检索当前tag的所有子孙节点,如果只想搜索tag的直接子节点,可以使用参数 recursive=False ;
limit:find_all() 方法返回全部的搜索结构,如果文档树很大那么搜索会很慢.如果我们不需要全部结果,可以使用 limit 参数限制返回结果的数量.效果与SQL中的limit关键字类似,当搜索到的结果数量达到 limit 的限制时,就停止搜索返回结果;
class_ :通过 class_ 参数搜索有指定CSS类名的tag,class_ 参数同样接受不同类型的 过滤器 ,字符串,正则表达式,方法或 True。

根据标签名字

lis = soup.find_all(nam)
for item in lis:
    print(item)

结果是

根据标签属性

属性和值以字典形式传入

lis = soup.find_all(attrs={"class":"s2"})
for item in lis:
    print(item)

结果是
作品名称
我能举报万物
女战神的黑包群
花岗岩之怒
超神机械师
无量真途
我的细胞监狱
前任无双
元阳道君
逆成长巨星
承包大明

限制搜索范围

find_all 方法会搜索当前标签的所有子孙节点,如果只想搜索直接子节点,可以使用参数 recursive=False

遍历获取子节点

.contents获取所有子节点

以列表形式返回所有子节点,要注意,列表里面还会掺杂 '/n'

ul = soup.ul
print(ul)
print(ul.contents)

结果是
['/n',

.children获取所有子节点

返回一个list生成器对象

ul = soup.ul
print(ul.children)
print(list(ul.children))

结果是
['/n', 

.descendants遍历所有子孙节点

ul = soup.ul
for item in ul.descendants:
    print(item)

结果是(中间很多'/n'空行我删掉了)
首页 首页 永久书架 永久书架 玄幻奇幻 玄幻奇幻 武侠仙侠 武侠仙侠 都市言情 都市言情 历史军事 历史军事 科幻灵异 科幻灵异 网游竞技 网游竞技 女频频道 女频频道 完本小说 完本小说 排行榜单 排行榜单 临时书架 临时书架

获取其父节点

a = soup.li.a
print(a)
p = a.parent
print(p)

结果是
首页

提取节点信息

节点名称

感觉没什么用

title = soup.title
print(title.name)

结果是
title

节点属性

a = soup.li.a
print(a)
print(a.attrs)    # 获取所有属性,返回字典形式
print(a['href'])# 获取a节点的href属性值

结果是
首页
{'href': '/'}
/

节点文本

a = soup.li.a
print(type(a.string)) # 节点内文本的类型
print(a.string) # 获取节点内的文本内容
print(a.get_text())    # 也是获取节点内的文本内容
结果是

首页

注意!!!如果节点内文本是注释,则用string取出文本时会自动去除注释标记
注释的类型:,可以通过类型判断

遍历获取所有子孙节点中的文本

for string in soup.stripped_strings:  # 去除多余空白内容
    print(repr(string))
想进一步了解编程开发相关知识,与我一同成长进步,请关注我的公众号“松果仓库”,共同分享宅&程序员的各类资源,谢谢!!!

审核编辑 黄昊宇
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • JAVA
    +关注

    关注

    20

    文章

    3006

    浏览量

    116835
  • 人工智能
    +关注

    关注

    1820

    文章

    50335

    浏览量

    266974
  • python
    +关注

    关注

    58

    文章

    4885

    浏览量

    90313
  • 爬虫
    +关注

    关注

    0

    文章

    87

    浏览量

    8176
收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    Python全栈一课通(470集)(12.96 GB)-网盘资源下载

    只懂单一节点的“螺丝钉”,往往是最先被优化、被降薪的群体。(看讠果aixuetang。xyz) 如果将《470集吃透 Python 全栈:Web 开发、接口、爬虫、自动化全包含》置于经济学的显微镜下,它
    发表于 04-19 16:30

    使用PYTHON进行的跨平台仿真

    如何使用编程语言Python来调用和控制VirtualLab Fusion中的模拟。请查看下面链接的文档,以找到关于如何设置和使用Python和VirtualLab Fusion之间的接口的详细指南,以及一个
    发表于 04-02 08:21

    [VirtualLab] 使用Python运行VirtualLab Fusion光学仿真

    摘要 VirtualLab Fusion允许Python外部访问其建模技术、求解器和结果。这个用例介绍了一种使用路径变量和Visual Studio代码将Python连接到VirtualLab
    发表于 03-31 09:39

    MAXM17516:高效电源模块的卓越

    MAXM17516:高效电源模块的卓越选 在电子设计领域,电源模块的性能直接影响着整个系统的稳定性和效率。今天,我们就来深入探讨一款备受关注的电源模块——MAXM17516。 文件下
    的头像 发表于 03-12 16:45 178次阅读

    京东关键词搜索商品列表的Python实战

    " return url def _parse_page(self, html): """解析页面,提取商品信息""" soup = BeautifulSoup(html, "html.parser
    的头像 发表于 01-09 10:34 1110次阅读

    京东关键词搜索商品列表的Python爬虫实战

    京东关键词搜索商品列表 Python 爬虫实战 你想要实现京东关键词搜索商品的爬虫,我会从 合规声明、环境准备、页面分析、代码实现、反爬优化 五个方面展开,帮助你完成实战项目。 一、前置声明(重要
    的头像 发表于 01-04 10:16 1279次阅读

    【睿擎派】EtherCAT总线IO模块读写

    在上一篇文章《【睿擎派】CANOpen总线IO模块读写(DS401协议)》我写了关于睿擎派上CANOpen的IO模块通信,为什么先写CANOpen?说来也有挺意思,是因为在睿擎派上对接
    的头像 发表于 12-31 19:07 5951次阅读
    【睿擎派】EtherCAT总线<b class='flag-5'>之</b>IO<b class='flag-5'>模块</b>读写

    没有专利的opencv-python 版本

    所有 官方发布的 opencv-python 核心版本(无 contrib 扩展)都无专利风险——专利问题仅存在于 opencv-contrib-python 扩展模块中的少数算法(如早期 SIFT
    发表于 12-13 12:37

    # 深度解析:爬虫技术获取淘宝商品详情并封装为API的全流程应用

    需求。本文将深入探讨如何借助爬虫技术实现淘宝商品详情的获取,并将其高效封装为API。 一、爬虫技术核心原理与工具 1.1 爬虫运行机制 网络爬虫本质上是一种遵循特定规则,自动抓取网页信
    的头像 发表于 11-17 09:29 490次阅读

    Python 给 Amazon 做“全身 CT”——可量产、可扩展的商品详情爬虫实战

    一、技术选型:为什么选 Python 而不是 Java? 结论: “调研阶段用 Python,上线后如果 QPS 爆表再考虑 Java 重构。” 二、整体架构速览(3 分钟看懂) 三、开发前准备(5
    的头像 发表于 10-21 16:59 628次阅读
    用 <b class='flag-5'>Python</b> 给 Amazon 做“全身 CT”——可量产、可扩展的商品详情<b class='flag-5'>爬虫</b>实战

    从 0 到 1:用 PHP 爬虫优雅地拿下京东商品详情

    PHP 语言 实现一个 可运行的京东商品爬虫 ,不仅能抓取商品标题、价格、图片、评价数,还能应对常见的反爬策略。全文附完整代码, 复制粘贴即可运行 。 一、为什么选择 PHP 做爬虫? 虽然 Python
    的头像 发表于 09-23 16:42 1070次阅读
    从 0 到 1:用 PHP <b class='flag-5'>爬虫</b>优雅地拿下京东商品详情

    Nginx限流与防爬虫配置方案

    在互联网业务快速发展的今天,网站面临着各种流量冲击和恶意爬虫的威胁。作为运维工程师,我们需要在保证正常用户访问的同时,有效防范恶意流量和爬虫攻击。本文将深入探讨基于Nginx的限流与防爬虫解决方案,从原理到实践,为大家提供一套完
    的头像 发表于 09-09 15:52 1084次阅读

    termux如何搭建python游戏

    termux如何搭建python游戏 Termux搭建Python游戏开发环境的完整指南 一、Termux基础环境准备 Termux是一款无需root即可在安卓设备上运行的Linux终端
    发表于 08-29 07:06

    python app不能运行怎么解决?

    ;python_agent[1241]: xmlrpc request method supervisor.stopProcess failed;python_agent[1241]: xmlrpc request method supervisor.stopProces
    发表于 08-06 06:27

    墨电能检测模块在教学场景中的应用

    工程训练中心的电工电子实验室里,学生们正围着一台风能发电装置进行调试。他们手中的黑色小方盒正实时显示着电流以及电压的波动数据--这是梦墨电能检测模块在教学场景中的应用。梦墨自主研发并推出的电能检测
    的头像 发表于 06-19 15:04 947次阅读
    梦<b class='flag-5'>之</b>墨电能检测<b class='flag-5'>模块</b>在教学场景中的应用