Python 通过requests实现腾讯新闻抓取爬虫的方法


Posted in Python onFebruary 22, 2019

最近也是学习了一些爬虫方面的知识。以我自己的理解,通常我们用浏览器查看网页时,是通过浏览器向服务器发送请求,然后服务器响应以后返回一些代码数据,再经过浏览器解析后呈现出来。而爬虫则是通过程序向服务器发送请求,并且将服务器返回的信息,通过一些处理后,就能得到我们想要的数据了。

以下是前段时间我用python写的一个爬取TX新闻标题及其网址的一个简单爬虫:

首先需要用到python中requests(方便全面的http请求库)和 BeautifulSoup(html解析库)。

通过pip来安装这两个库,命令分别是:pip install requests 和 pip install bs4 (如下图)

Python 通过requests实现腾讯新闻抓取爬虫的方法

先放上完整的代码

# coding:utf-8
import requests
from bs4 import BeautifulSoup
 
url = "http://news.qq.com/"
# 请求腾讯新闻的URL,获取其text文本
wbdata = requests.get(url).text
# 对获取到的文本进行解析
soup = BeautifulSoup(wbdata,'lxml')
# 从解析文件中通过select选择器定位指定的元素,返回一个列表
news_titles = soup.select("div.text > em.f14 > a.linkto")
 
# 对返回的列表进行遍历
for n in news_titles:
  title = n.get_text()
  link = n.get("href")
  data = {
    '标题':title,
    '链接':link
  }
  print(data)

首先引入上述两个库

import requests
from bs4 import BeautifulSoup

然后get请求腾讯新闻网url,返回的字符串实质上就是我们手动打开这个网站,然后查看网页源代码所看到的html代码。

wbdata = requests.get(url).text

我们需要的仅仅是某些特定标签里的内容:

Python 通过requests实现腾讯新闻抓取爬虫的方法

Python 通过requests实现腾讯新闻抓取爬虫的方法

可以看出,每条新闻链接、标题都在<div class="text">标签的<em class="f14 124">标签下

之后我们将刚刚请求得到的html代码进行处理,这时候就需要用到BeautifulSoap库了

soup = BeautifulSoup(wbdata,'lxml')

这一行的意思是对获取的信息进行解析处理,也可以将lxml库换成html.parser库,效果是相同的

news_titles = soup.select("div.text > em.f14 > a.linkto")

这一行是利用刚刚经过解析获取的soup对象,选择我们需要的标签,返回值是一个列表。列表中存放了我们需要的所有标签内容。也可以使用BeautifulSoup中的find()方法或findall()方法来对标签进行选择。

最后用 for in 对列表进行遍历,分别取出标签中的内容(新闻标题)和标签中href的值(新闻网址),存放在data字典中

for n in news_titles:
  title = n.get_text()
  link = n.get("href")
  data = {
    '标题':title,
    '链接':link
  }

data存放的就是所有的新闻标题和链接了,下图是部分结果

Python 通过requests实现腾讯新闻抓取爬虫的方法

这样一个爬虫就完成了,当然这只是一个最简单的爬虫。深入爬虫的话还有许多模拟浏览器行为、安全问题、效率优化、多线程等等需要考虑,不得不说爬虫是一个很深的坑。

python中爬虫可以通过各种库或者框架来完成,requests只是比较常用的一种而已。其他语言中也会有许多爬虫方面的库,例如php可以使用curl库。爬虫的原理都是一样的,只是用不同语言、不同库来实现的方法不一样。

以上这篇Python 通过requests实现腾讯新闻抓取爬虫的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Win7上搭建Cocos2d-x 3.1.1开发环境
Jul 03 Python
python读取word文档的方法
May 09 Python
Python实现JSON反序列化类对象的示例
Jan 31 Python
数据清洗--DataFrame中的空值处理方法
Jul 03 Python
Python3实现的判断回文链表算法示例
Mar 08 Python
django项目中使用手机号登录的实例代码
Aug 15 Python
对Django的restful用法详解(自带的增删改查)
Aug 28 Python
用openCV和Python 实现图片对比,并标识出不同点的方式
Dec 19 Python
Anaconda+VSCode配置tensorflow开发环境的教程详解
Mar 30 Python
python 已知平行四边形三个点,求第四个点的案例
Apr 12 Python
Python如何实现远程方法调用
Aug 07 Python
获取CSDN文章内容并转换为markdown文本的python
Sep 06 Python
解决python3.5 正常安装 却不能直接使用Tkinter包的问题
Feb 22 #Python
浅谈python3.6的tkinter运行问题
Feb 22 #Python
Scrapy框架爬取西刺代理网免费高匿代理的实现代码
Feb 22 #Python
在Python运行时动态查看进程内部信息的方法
Feb 22 #Python
Python开启线程,在函数中开线程的实例
Feb 22 #Python
python 多线程串行和并行的实例
Feb 22 #Python
Python OOP类中的几种函数或方法总结
Feb 22 #Python
You might like
PHP闭包(Closure)使用详解
2013/05/02 PHP
PHP字符串的连接的简单实例
2013/12/30 PHP
php实现字符串首字母大写和单词首字母大写的方法
2015/03/14 PHP
PHP下载文件函数与用法示例
2019/09/27 PHP
用JS实现一个页面多个css样式实现
2008/05/29 Javascript
Javascript入门学习资料收集整理篇
2008/07/06 Javascript
JS无限树状列表实现代码
2011/01/11 Javascript
前端开发过程中浏览器版本的两种判定方法
2013/10/30 Javascript
Javascript中对象继承的实现小例
2014/05/12 Javascript
5款JavaScript代码压缩工具推荐
2014/07/07 Javascript
学习使用grunt来打包JavaScript和CSS程序的教程
2016/01/04 Javascript
详解WordPress开发中get_current_screen()函数的使用
2016/01/11 Javascript
微信小程序 教程之模块化
2016/10/17 Javascript
js 打开新页面在屏幕中间的实现方法
2016/11/02 Javascript
JS定时检测任务任务完成后执行下一步的解决办法
2016/12/22 Javascript
js数组与字符串常用方法总结
2017/01/13 Javascript
jQuery点击页面其他部分隐藏下拉菜单功能
2018/11/27 jQuery
微信小程序实现用table显示数据库反馈的多条数据功能示例
2019/05/07 Javascript
Vue中import from的来源及省略后缀与加载文件夹问题
2020/02/09 Javascript
[00:09]DOTA2全国高校联赛 精彩活动引爆全场
2018/05/30 DOTA
Python高效编程技巧
2013/01/07 Python
python协程用法实例分析
2015/06/04 Python
在Python的Django框架中包装视图函数
2015/07/20 Python
python调用fortran模块
2016/04/08 Python
python执行系统命令后获取返回值的几种方式集合
2018/05/12 Python
Python中的 is 和 == 以及字符串驻留机制详解
2019/06/28 Python
wxpython绘制音频效果
2019/11/18 Python
屏蔽Django admin界面添加按钮的操作
2020/03/11 Python
Selenium元素定位的30种方式(史上最全)
2020/05/11 Python
基于Python实现下载网易音乐代码实例
2020/08/10 Python
python安装sklearn模块的方法详解
2020/11/28 Python
新闻专业大学生找工作的自我评价
2013/10/30 职场文书
教师节活动总结
2014/08/29 职场文书
机关干部作风建设剖析材料
2014/10/23 职场文书
2015年煤矿工作总结
2015/04/28 职场文书
Pygame Draw绘图函数的具体使用
2021/11/17 Python