Python爬虫教程-24-数据提取-BeautifulSoup4(二)
2021-07-04 23:06
标签:attrs 文本 python爬虫 src mpi soup head .net 案例 本篇介绍 bs 如何遍历一个文档对象 Python爬虫教程-24-数据提取-BeautifulSoup4(二) 标签:attrs 文本 python爬虫 src mpi soup head .net 案例 原文地址:https://www.cnblogs.com/xpwi/p/9600957.htmlPython爬虫教程-24-数据提取-BeautifulSoup4(二)
遍历文档对象
# BeautifulSoup 的使用案例
# 遍历文档对象
from urllib import request
from bs4 import BeautifulSoup
url = ‘http://www.baidu.com/‘
rsp = request.urlopen(url)
content = rsp.read()
soup = BeautifulSoup(content, ‘lxml‘)
# bs 自动解码
content = soup.prettify()
print("=="*12)
# 使用 contents
for node in soup.head.contents:
if node.name == "meta":
print(node)
if node.name == "title":
print(node.string)
print("=="*12)
运行结果
常用string打印出标签的具体内容,不带有标签,只有内容
当然,如果觉得遍历太耗费资源,没有必要遍历的时候,可以使用搜索搜索文档对象
例如:我们需要打印所有以 me 开头的标签内容
tags = soup.find_all(re.compile(‘^me‘))# BeautifulSoup 的使用案例
# 搜索文档对象
from urllib import request
from bs4 import BeautifulSoup
import re
url = ‘http://www.baidu.com/‘
rsp = request.urlopen(url)
content = rsp.read()
soup = BeautifulSoup(content, ‘lxml‘)
# bs 自动解码
content = soup.prettify()
# 使用 find_all
# 使用 name 参数
print("=="*12)
tags = soup.find_all(name=‘link‘)
for i in tags:
print(i)
# 使用正则表达式
print("=="*12)
# 同时使用两个条件
tags = soup.find_all(re.compile(‘^me‘), content=‘always‘)
# 这里直接打印 tags 会打印一个列表
for i in tags:
print(i)
运行结果
因为使用两个条件,所以只匹配到一条 meta
下一篇介绍,BeautifulSoup 的 css 选择器
拜拜
- 本笔记不允许任何个人和组织转载
文章标题:Python爬虫教程-24-数据提取-BeautifulSoup4(二)
文章链接:http://soscw.com/index.php/essay/101903.html