Python学习,还在用正则或者bs4做爬虫吗?来试试css选择器吧

news/2024/7/19 10:11:35 标签: 爬虫, python, 数据库

之前写的一些爬虫都是用的正则、bs4、xpath做为解析库来实现,如果你对web有所涉及,并且比较喜欢css选择器,那么就有一个更适合的解析库—— PyQuery。我们就用一个非常简单的小例子来看看css选择器做爬虫是怎么样的!

安装

直接pip安装即可:pip install pyquery

安装完成后,运行 pip show pyquery,如果出现相关信息即为安装完成!

如果pip安装失败,可以去官网https://pypi.org/project/pyquery/#downloads下载wheel文件,然后用pip安装即可,注意文件名字要写全,比如:pip install pyquery-1.2.17-py2.py3-none-any.whl ,该命令请在同一目录下使用。

Python学习,还在用正则或者bs4做<a class=爬虫吗?来试试css选择器吧" title="" />

使用

确保安装成功后就可以开始使用了,它和其他库一样,PyQuery 初始化的时候也需要传入 HTML 数据源来初始化一个操作对象,它的初始化方式有多种,比如直接传入字符串,传入 URL,传文件名。

我们用requests库搭配来写个简单的抓取凤凰新闻的小爬虫,方便理解:

打开凤凰网——资讯——即时新闻,我们就以抓取这个页面的所有新闻为例吧!

Python学习,还在用正则或者bs4做<a class=爬虫吗?来试试css选择器吧" title="" />

这里没有反爬,页数也不是很多(4页),非常方便用来讲解!分析下网页结构后发现,所有的新闻目录都存在于网页源代码中,每页大概有60多条,我们先来抓取一页的标题和url试试

Python学习,还在用正则或者bs4做<a class=爬虫吗?来试试css选择器吧" title="" />

可以看到,标题和url都在class=newsList的div下的ul->li->a标签下(用a标签的target属性匹配的话太多,不好清洗),我们可以直接写如代码去获取相关内容了,如下图:

Python学习,还在用正则或者bs4做<a class=爬虫吗?来试试css选择器吧" title="" />

前面是常规的requests库获取源代码html,然后用PyQuery解析网页源代码,重点是后面的定位到a标签和取出内容。

doc(‘.newsList ul a’) 的意思是定位class属性为newsList的标签下面的ul下面的a标签,注意newsList前面有个点,代表class属性,ul和a标签之间有个li标签,因为ul下的a标签是唯一,所以省略了(ul标签没有省略是因为最下面翻页部分也在这个div下,省略会有其他内容出现,下面会单独提取)!然后定位到a标签后,用items()方法将所有的a标签取出,然后遍历取出里面的内容。

这里提取标签的内容用了2个方法text()和attr():

text()方法,可以提取出标签下的所有文本内容,注意是所有!!!

attr()方法,取出标签的某属性,2中写法都可以:new.attr.href 和new.attr(‘href’)

然后在看翻页,我们只需要判断是否存在下一页,存在时,查找所有的标题和url,然后获取下一页的url,继续查找,直到不存在下一页,所有的页面就都遍历过了!为了方便,直接做成了一个函数,来看代码

Python学习,还在用正则或者bs4做<a class=爬虫吗?来试试css选择器吧" title="" />

这里同样的用class属性来定位,找到它下的a标签,然后判断‘下一页’是否存在a标签的文本中,存在则取出下一页的url,然后再次调用函数,不存在则退出!

这样,我们就得到了4页所有的title和url的内容,在来看看新闻详情页的情况,所有的网页文本内容都在id=”main_content”的div下的好多p标签中,那么就用到了text()方法了!来看图

Python学习,还在用正则或者bs4做<a class=爬虫吗?来试试css选择器吧" title="" />

这样,我们就取到了所有内容,整合下,最后代码如下:

Python学习,还在用正则或者bs4做<a class=爬虫吗?来试试css选择器吧" title="" />

Python学习,还在用正则或者bs4做<a class=爬虫吗?来试试css选择器吧" title="" />

随手写的代码,就不写入文本或者数据库什么了,主要是学习css选择器的使用!

最后

​到这里PyQuery 的用法就介绍完了,当然只是用到了很少一部分,还有好多功能没有在这里使用,大家有兴趣可以去看看官方文档或者教程,而且css选择器也可以使用在scrapy框架!是非常方便的一种方式!

现在学习python的人越来越多,很多人还在找资料,或者疑问哪本书是否有用,或者想找个可以指导的老师,或者在寻找一起学习的小伙伴,如果你也是需要资料或者需要帮助的话,可以关注我,私信一起来交流学习!


http://www.niftyadmin.cn/n/1661199.html

相关文章

Centos7 安装Mysql 5.7

官网安装教程&#xff1a;https://dev.mysql.com/doc/refman/5.7/en/linux-installation-yum-repo.html1、下载mysql yum库 最新版本请在此查看 &#xff1a; http://dev.mysql.com/downloads/repo/yum/wget https://repo.mysql.com//mysql57-community-release-el7-11.noarch…

18年总结

2018 明天就是新的一年&#xff0c;18年发生了很多的事情与改变&#xff0c;就像今天的这份个人总结&#xff08;原本是不会写总结的&#xff09;之前每到年底时候是有想过一整年发生的事情&#xff0c;并且计划着新一年要干成的大事&#xff0c;但那些都只是在脑海中想着一幅幅…

Android 即时通讯开发小结(二)

《Android 即时通讯开发小结》基于IM Andriod 开发的各种常见问题&#xff0c;结合网易云信即时通讯技术的实践&#xff0c;对IM 开发做一个全面的总结。 相关推荐阅读&#xff1a;、 Android 即时通讯开发小结&#xff08;一&#xff09; 移动IM开发指南1&#xff1a;如何进行…

关于Tensorflow 训练时越来越慢,重启又好了

用的是Tensorflow 1.2版本&#xff0c;在CPU上跑&#xff0c;大概就是才开始训练的时候每个batch的时间很低&#xff0c;然后随着训练的推进&#xff0c;每个batch的耗时越来越长&#xff0c;但是当我重启后&#xff0c;又一切正常了&#xff0c;不知道这个是什么问题&#xff…

Windows Server 2016-DNS客户端新增功能

域名系统&#xff08;DNS&#xff09;是包含TCP / IP的行业标准协议套件之一&#xff0c;DNS客户端和DNS服务器一起为计算机和用户提供计算机名称到IP地址映射名称解析服务。在Windows Server 2016中&#xff0c;DNS是可以使用服务器管理器或Windows PowerShell命令安装的服务器…

RHCSA考试环境

RHCSA 7 答题参考(上午)考试环境说明 ——真实机(无 root 权限):foundation.domainX.example.com虚拟机(有 root 权限):station.domainX.example.com考试服务器(提供 DNS/YUM/认证/素材.. ..):rhgls.domainX.example.com、host.domainX.example.com练习环境说明 ——真实机(无 …

101:Django数据库练习题

以后补转载于:https://www.cnblogs.com/zheng-weimin/p/10403973.html

小程序实践(二):swiper组件实现轮播图效果

swiper组件类似于Android中的ViewPager&#xff0c;实现类似轮播图的效果&#xff0c;相对于Android的Viewpager,swiper实现起来更加方便&#xff0c;快捷。 效果图&#xff1a; 首先看下swiper支持的属性&#xff1a; ------------------------------------------------------…