首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Python爬虫:我这有美味的汤,你喝吗

使用Beautiful Soup 在前面的文章中已经讲过了正则表达式的使用方法了,但是如果正则表达式出现问题,那么得到的结果就不是我们想要的内容。...提取节点信息 从上面的代码我们知道可以使用string属性获取文本的内容。但是有些时候我需要获取节点属性的值,或者节点名。 (1)获取名称 可以利用name属性获取节点的名称。...原因是:class这个属性可以有多个值,所以将其保存在列表中 (4)获取内容 可以利用string属性获取节点元素包含的文本内容,比如要获取第一个p节点的文本。...')) print(len(soup.find_all('a'))) 上面的代码调用了find_all( )方法,传入了name参数,参数值为a, 试着运行上面的代码,我们想要获取的所有a节点,返回结果是列表类型...') print(soup.find_all(id = 'link2')) find( ) 除了find_all( )方法,还有find( )方法,前者返回的是多个元素,以列表形式返回,后缀是返回一个元素

2.4K10
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Python爬虫技术系列-02HTML解析-BS4

    在 BS4 中,通过标签名和标签属性可以提取出想要的内容。...) #返回一个字典,里面是多有属性和值 print(soup.div.p.attrs) #查看返回的数据类型 print(type(soup.div.p)) #根据属性,获取标签的属性值,返回值为列表...limit:由于 find_all() 会返回所有的搜索结果,这样会影响执行效率,通过 limit 参数可以限制返回结果的数量 find()函数是find_all()的一种特例,仅返回一个值。...参数值 print(soup.find(attrs={'class':'vip'})) # 使用 find() 时,如果没有找到查询标签会返回 None,而 find_all() 方法返回空列表。...Beautiful Soup 提供了一个 select() 方法,通过向该方法中添加选择器,就可以在 HTML 文档中搜索到与之对应的内容。

    9K20

    Python 爬虫解析库的使用

    解析库的使用--Beautiful Soup: BeautifulSoup是Python的一个HTML或XML解析库,最主要的功能就是从网页爬取我们需要的数据。...Beautiful Soup3 目前已经停止开发,我们推荐在现在的项目中使用Beautiful Soup4, 1....BeautifulSoup 安装与使用: Beautiful Soup是一个依赖于lxml的解析库,所以在安装之前要先确保lxml库已安装:pip install lxml 安装 BeautifulSoup...element.Tag'> print(soup.body.h3.string) #获取body中的第一个h3中的文本内容:我的常用链接 ④ 关联选择: 我们在做选择的时候,难免有时候不能够一步就选到想要的节点元素...# 子或子孙节点 # 以下获取的节点列表都可以使用for...in遍历 print(soup.ul.contents) #获取ul下面的所有直接子节点,返回列表 print(soup.ul.children

    2.7K20

    网页解析

    Beautiful Soup 官方中文文档 搜索过程: 根据结构化解析的方式将对html的节点按照节点的名称/属性/文字进行搜索: Beautiful使用方法为: 首先根据html网页和解析编码方式创建一个...bs对象 调用find_all或者find方法对节点进行搜索,或者使用find()返回第一个匹配结果 对于搜索到的结果 find all(name,attrs,string)其中name参数表示节点的标签名称...class后加'_'是因为python的保留字 soup.find_all('div',class_='abc',string='Python') find_all方法会返回所有满足要求的节点的列表(tag...对象组成的列表),至于节点内容的提取则需要借助get方法(提取属性)或者ger_text()方法(提取文本段落)。...具体使用方法可以见之前的一次爬虫实战——爬取壁纸 由于 Beautiful Soup 的解析是基于正则表达式的(’html.parser’),用在缺乏正确标签结构的破损网页上很有效。

    3.2K30

    Python爬虫 Beautiful Soup库详解

    使用 Beautiful Soup 前面介绍了正则表达式的相关用法,但是一旦正则表达式写的有问题,得到的可能就不是我们想要的结果了。...这一节中,我们就来介绍一个强大的解析工具 Beautiful Soup,它借助网页的结构和属性等特性来解析网页。...比如,name 属性的值是唯一的,返回的结果就是单个字符串。而对于 class,一个节点元素可能有多个 class,所以返回的是列表。在实际处理过程中,我们要注意判断类型。...关联选择 在做选择的时候,有时候不能做到一步就选到想要的节点元素,需要先选中某一个节点元素,然后以它为基准再选择它的子节点、父节点、兄弟节点等,这里就来介绍如何选择这些节点元素。...这里在 find_all() 方法中传入 text 参数,该参数为正则表达式对象,结果返回所有匹配正则表达式的节点文本组成的列表。

    25610

    BeautifulSoup4用法详解

    这篇文档介绍了BeautifulSoup4中所有主要特性,并且有小例子.让我来向你展示它适合做什么,如何工作,怎样使用,如何达到你想要的效果,和处理异常情况....提示: 如果一段HTML或XML文档格式不正确的话,那么在不同的解析器中返回的结果可能是不一样的,查看 解析器之间的区别 了解更多细节 如何使用 将一段文档传入BeautifulSoup 的构造方法,就能得到一个文档的对象..., recursive , text , **kwargs ) find_all() 方法将返回文档中符合条件的所有tag,尽管有时候我们只想得到一个结果.比如文档中只有一个标签,那么使用...story 唯一的区别是 find_all() 方法的返回结果是值包含一个元素的列表,而 find() 方法直接返回结果. find_all() 方法没有找到目标是返回空列表, find...错误通常是因为把 find_all() 的返回结果当作一个tag或文本节点使用,实际上返回结果是一个列表或 ResultSet 对象的字符串,需要对结果进行循环才能得到每个节点的 .foo 属性.或者使用

    10.1K21

    HTML解析大法|牛逼的Beautiful Soup!

    看官方怎么说的---“Beautiful Soup 3 目前已经停止开发,我们推荐在现在的项目中使用Beautiful Soup 4, 移植到BS4”,没错,停止开发了,所以我们也没什么必要去学习3的知识...$ easy_install beautifulsoup4$ pip install beautifulsoup4 (在PyPi中还有一个名字是 BeautifulSoup 的包,但那可能不是你想要的...""" 我们之后的操作都是基于上面这个字符串来的,我们使用BeautifulSoup解析这段代码,能够得到一个 BeautifulSoup 的对象,并能按照标准的缩进格式的结构输出: #...如果一个指定的名字的参数不是搜索的参数名,这个时候搜索的是指定名字的Tag的属性。搜索指定名字的属性时可以使用的参数值包括字符串、正则表达式、列表、True。...recursive:调用tag的find_all()方法时,Beautiful Soup会检索当前tag的所有子孙节点,如果只想搜索tag的直接子节点,可以使用该参数并且将值为False。

    1.5K20

    Python 页面解析:Beautiful Soup库的使用

    本文内容:Python 页面解析:Beautiful Soup库的使用 ---- Python 页面解析:Beautiful Soup库的使用 1.Beautiful Soup库简介 2.Beautiful...()与find()两个常用的查找方法它们的用法如下: 2.1 find_all() find_all() 方法用来搜索当前 tag 的所有子节点,并判断这些节点是否符合过滤条件,最后以列表形式将符合条件的内容返回...attrs:按照属性名和属性值搜索 tag 标签,注意由于 class 是 Python 的关键字,所以要使用 “class_”。...text:用来搜文档中的字符串内容,该参数可以接受字符串 、正则表达式 、列表、True。...Beautiful Soup 提供了一个 select() 方法,通过向该方法中添加选择器,就可以在 HTML 文档中搜索到与之对应的内容。

    1.7K20

    使用 Beautiful Soup 解析网页内容

    第一步是建立BeautifulSoup对象,这个对象在bs4模块中。注意在建立对象的时候可以额外指定一个参数,作为实际的HTML解析器。...在标签对象上,我们可以调用一些查找方法例如find_all等等,还有一些属性返回标签的父节点、兄弟节点、直接子节点、所有子节点等。在文本对象上,我们可以调用.string属性获取具体文本。...使用方式主要有两种:一是直接引用属性,就是soup.title这样的,会返回第一个符合条件的节点;二是通过查找方法例如find_all这样的,传入查询条件来查找结果。 再来说说查询条件。...查询条件可以是:字符串,会返回对应名称的节点;正则表达式,按照正则表达式匹配;列表,会返回所有匹配列表元素的节点;真值True,会返回所有标签节点,不会返回字符节点;方法,我们可以编写一个方法,按照自己的规则过滤...这里需要说明一下,查询方法返回的是结果集,对结果集遍历可以得到标签或者文本对象。如果调用标签对象的.contents,会返回一个列表,列表内是标签、文本或注释对象。

    3.1K90

    Python爬虫库-BeautifulSoup的使用

    Beautiful Soup是一个可以从HTML或XML文件中提取数据的Python库,简单来说,它能将HTML的标签文件解析成树形结构,然后方便地获取到指定标签的对应属性。...属性只能获取到第一个tag,若想获取到所有的 li 标签,可以通过 find_all() 方法 ls = soup.article.div.ul.find_all('li') 获取到的是包含所有li标签的列表...tag的 .contents 属性可以将tag的子节点以列表的方式输出: tag = soup.article.div.ul contents = tag.contents 打印 contents 可以看到列表中不仅包含了...) 的搜索方法只会返回第一个满足要求的结果,等价于 find_all() 方法并将limit设置为1。...当没有搜索到满足条件的标签时,find() 返回 None, 而 find_all() 返回一个空的列表。

    1.8K30

    二、爬虫基础库

    (1) 子节点 一个Tag可能包含多个字符串或其它的Tag,这些都是这个Tag的子节点.Beautiful Soup提供了许多操作和遍历子节点的属性....注意: Beautiful Soup中字符串节点不支持这些属性,因为字符串没有子节点。...兄弟节点可以理解为和本节点处在统一级的节点,.next_sibling 属性获取了该节点的下一个兄弟节点,.previous_sibling 则与之相反,如果节点不存在,则返回 None 在文档树中,...,正则表达式,列表,方法或是 True .  传字符串 最简单的过滤器是字符串.在搜索方法中传入一个字符串参数,Beautiful Soup会查找与字符串完整匹配的内容,下面的例子用于查找文档中所有的...^b")): print(tag.name) # body # b  传列表 如果传入列表参数,Beautiful Soup会将与列表中任一元素匹配的内容返回.下面代码找到文档中所有

    1.8K90

    python3 爬虫笔记(一)beaut

    很多人学习python,爬虫入门,在python爬虫中,有很多库供开发使用。...) # 获取名称 print(soup.div.name) # 获取属性 属性值多个,所以返回值为list列表 print(soup.div.attrs) # 元素选择可以嵌套 ,这样的方式在多个的情况下...,只取第一个, # 比如body中有多个div,这里取了第一个 print(soup.body.div.a.attrs) # contents 属性获取直接的子节点 children属性也是如此 用属性选择较快...,但是遇到复杂的情况,就很不灵活,这时候我们需要调用beautiful_soup中的一些方法# find_all 查询所有符合条件的元素 # find_all(name, attrs, recursive..."})) # text print(soup.find_all(text=re.compile("热"))) # find() 用法和find_all()一致,只不过返回的是单个元素,匹配到的第一个

    50830

    一文入门BeautifulSoup

    如果想获取到所有a标签的值,使用find_all方法 ? contents contents属相将tag的子节点以列表的形式输出,获取到的是标签中的内容部分 ?...过滤器贯穿整个搜索的API。它们可以被使用在tag的name中,节点的属性中,字符串或者它们的混合中,具体见下面的实例 传入字符串 直接传入需要查找的某个标签,会将结果以列表的形式展示出来 ?...recursive 调用tag的 find_all() 方法时,Beautiful Soup会检索当前tag的所有子孙节点,如果只想搜索tag的直接子节点,可以使用参数 recursive=False,...find() find(name,attrs,text,recursive,**kwargs) 它与 find_all() 方法唯一的区别是 find_all() 方法的返回结果是值包含一个元素的列表,...CSS选择器 在写CSS的时候,类名前加上点,id名前加上#。 使用soup.select()的方法类筛选元素,返回的类型是list 标签名查找 ? 类名查找 ? id名查找 ?

    3.9K00

    Python爬虫库-Beautiful Soup的使用

    Beautiful Soup是一个可以从HTML或XML文件中提取数据的Python库,简单来说,它能将HTML的标签文件解析成树形结构,然后方便地获取到指定标签的对应属性。...属性只能获取到第一个tag,若想获取到所有的 li 标签,可以通过 find_all() 方法 ls = soup.article.div.ul.find_all('li') 获取到的是包含所有li标签的列表...tag的 .contents 属性可以将tag的子节点以列表的方式输出: tag = soup.article.div.ul contents = tag.contents 打印 contents 可以看到列表中不仅包含了...的搜索方法只会返回第一个满足要求的结果,等价于 find_all() 方法并将limit设置为1。...当没有搜索到满足条件的标签时,find() 返回 None, 而 find_all() 返回一个空的列表。

    1.6K30

    六、解析库之Beautifulsoup模块

    .你可能在寻找 Beautiful Soup3 的文档,Beautiful Soup 3 目前已经停止开发,官网推荐在现在的项目中使用Beautiful Soup 4, 移植到BS4 #安装 Beautiful...,但如果存在多个相同的标签则只返回第一个 #1、用法 #2、获取标签的名称 #3、获取标签的属性 #4、获取标签的内容 #5、嵌套选择 #6、子节点、子孙节点 #7、父节点、祖先节点 #8、兄弟节点 #...'^b'))) #找出b开头的标签,结果有body和b标签 #1.3、列表:如果传入列表参数,Beautiful Soup会将与列表中任一元素匹配的内容返回.下面代码找到文档中所有标签和标签..._ print(soup.find_all(id=True)) #查找有id属性的标签 # 有些tag属性在搜索不能使用,比如HTML5中的 data-* 属性: data_soup = BeautifulSoup...tag,尽管有时候我们只想得到一个结果.比如文档中只有一个标签,那么使用 find_all() 方法来查找标签就不太合适, 使用 find_all 方法并设置 limit=1 参数不如直接使用

    1.7K60

    Python爬虫学习笔记之爬虫基础库

    注意: Beautiful Soup中字符串节点不支持这些属性,因为字符串没有子节点。...兄弟节点可以理解为和本节点处在统一级的节点,.next_sibling 属性获取了该节点的下一个兄弟节点,.previous_sibling 则与之相反,如果节点不存在,则返回 None 在文档树中,...,正则表达式,列表,方法或是 True .  传字符串 最简单的过滤器是字符串.在搜索方法中传入一个字符串参数,Beautiful Soup会查找与字符串完整匹配的内容,下面的例子用于查找文档中所有的...^b")): print(tag.name) # body # b  传列表 如果传入列表参数,Beautiful Soup会将与列表中任一元素匹配的内容返回.下面代码找到文档中所有...>The Dormouse's story 唯一的区别是 find_all() 方法的返回结果是值包含一个元素的列表,而 find() 方法直接返回结果. find_all() 方法没有找到目标是返回空列表

    1.8K20

    BeautifulSoup使用

    一个Tag可能包含多个字符串或其它的Tag,这些都是这个Tag的子节点.Beautiful Soup提供了许多操作和遍历子节点的属性.注意: Beautiful Soup中字符串节点不支持这些属性,因为字符串没有子节点...通过点取属性的方式只能获得当前名字的第一个tag,如果想要得到所有的标签,或是通过名字得到比一个tag更多的内容的时候,就需要用到 Searching the tree 中描述的方法,比如: find_all...'] .contents 和 .children、.descendants tag的 .contents 属性可以将tag的子节点以列表的方式输出,.children与contents的区别在于它将返回一个迭代器...tag的所有tag子节点,并判断是否符合过滤器的条件 name 参数 传字符串 最简单的过滤器是字符串.在搜索方法中传入一个字符串参数,Beautiful Soup会查找与字符串完整匹配的内容,下面的例子用于查找文档中所有的...^b")): print(tag.name) # body # b 传列表 如果传入列表参数,Beautiful Soup会将与列表中任一元素匹配的内容返回.下面代码找到文档中所有标签和

    96630

    python 爬虫之BeautifulS

    html内容过滤为你所想要的 url_name = line.get('href') 获取a标签的url信息 Title = line.get_text().strip() 获取a标签的文本内容 Beautiful...(markup, “html5lib”) Beautiful Soup将复杂HTML文档转换成一个复杂的树形结构,每个节点都是Python对象 soup.p.attrs 获取标签p的属性信息 find_all...()直接返回结果 find_all() 和 find() 只搜索当前节点的所有子节点,孙子节点等. find_parents() 和 find_parent() 用来搜索当前节点的父辈节点,搜索方法与普通...节点 find_previous_siblings() 方法返回所有符合条件的前面的兄弟节点, find_previous_sibling() 方法返回第一个符合条件的前面的兄弟节点 find_all_next...() 方法返回所有符合条件的节点, find_next() 方法返回第一个符合条件的节点 find_all_previous() 方法返回所有符合条件的节点, find_previous()方法返回第一个符合条件的节点

    80420
    领券