BeautifulSoup常用语法有哪些

本篇内容主要讲解“BeautifulSoup常用语法有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“BeautifulSoup常用语法有哪些”吧!

创新互联公司专注于企业全网整合营销推广、网站重做改版、蒙城网站定制设计、自适应品牌网站建设、H5建站商城网站制作、集团公司官网建设、外贸营销网站建设、高端网站制作、响应式网页设计等建站业务,价格优惠性价比高,为蒙城等各大城市提供网站开发制作服务。

解析库

BeautifulSoup默认支持Python的标准HTML解析库,但是它也支持一些第三方的解析库

解析库使用方法优势劣势
Python标准库BeautifulSoup(html,’html.parser’)Python内置标准库;执行速度快容错能力较差
lxml HTML解析库BeautifulSoup(html,’lxml’)速度快;容错能力强需要安装,需要C语言库
lxml XML解析库BeautifulSoup(html,[‘lxml’,’xml’])速度快;容错能力强;支持XML格式需要C语言库
htm5lib解析库BeautifulSoup(html,’htm5llib’)以浏览器方式解析,最好的容错性速度慢

代码示例

demo html




 
  
  
  
  
  百度一下,你就知道 
 
 
  
   
    
     
      
       新闻 
      
       hao123 
      
       地图 
      
       视频 
      
       贴吧 
      
       更多产品 
     
    
   
  
 

创建beautifulsoup4对象

from bs4 import BeautifulSoup

soup = BeautifulSoup(html,"html.parser")

# 缩进格式
print(soup.prettify())

# 获取title标签的所有内容
print(soup.title)
#Output:百度一下,你就知道 

# 获取title标签的名称
print(soup.title.name)
#Output:title

# 获取title标签的文本内容
print(soup.title.string)
#Output:百度一下,你就知道

# 获取head标签的所有内容
print(soup.head)

# 获取第一个div标签中的所有内容
print(soup.div)

# 获取第一个div标签的id的值
print(soup.div["id"])

# 获取第一个a标签中的所有内容
print(soup.a)

# 获取所有的a标签中的所有内容
print(soup.find_all("a"))

# 获取id="u1"
print(soup.find(id="u1"))

# 获取所有的a标签,并遍历打印a标签中的href的值
for item in soup.find_all("a"):
	print(item.get("href"))

# 获取所有的a标签,并遍历打印a标签的文本值
for item in soup.find_all("a"):
	print(item.get_text())

BeautifulSoup4四大对象种类

BeautifulSoup4将复杂HTML文档转换成一个复杂的树形结构,每个节点都是Python对象,所有对象可以归纳为4种:

遍历文档树

# tag的.content 属性可以将tag的子节点以列表的方式输出
print(soup.head.contents)

# 用列表索引来获取它的某一个元素
print(soup.head.contents[1])
for child in  soup.body.children:
    print(child)

搜索文档树

返回符合条件的第一个Tag,即当我们要取一个值的时候就可以用这个方法

t = soup.div.div

# 等价于
t = soup.find("div").find("div")

CSS选择器

print(soup.select('title'))

print(soup.select('a'))
print(soup.select('.mnav'))
print(soup.select('#u1'))
print(soup.select('div .bri'))
print(soup.select('a[class="bri"]'))
print(soup.select('a[href="http://tieba.baidu.com"]'))
item_list = soup.select("title")
print(soup.select('title')[0].get_text())

到此,相信大家对“BeautifulSoup常用语法有哪些”有了更深的了解,不妨来实际操作一番吧!这里是创新互联网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!


分享名称:BeautifulSoup常用语法有哪些
转载源于:http://pwwzsj.com/article/pcgjdg.html

其他资讯