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 相关文章推荐
35个Python编程小技巧
Apr 01 Python
使用Python脚本将绝对url替换为相对url的教程
Apr 24 Python
解析Python中的二进制位运算符
May 13 Python
Python实现屏幕截图的代码及函数详解
Oct 01 Python
Python中装饰器兼容加括号和不加括号的写法详解
Jul 05 Python
对Python 网络设备巡检脚本的实例讲解
Apr 22 Python
selenium+python设置爬虫代理IP的方法
Nov 29 Python
详解Django-auth-ldap 配置方法
Dec 10 Python
python机器学习包mlxtend的安装和配置详解
Aug 21 Python
导入tensorflow时报错:cannot import name 'abs'的解决
Oct 10 Python
python 实现Harris角点检测算法
Dec 11 Python
利用python实现汉诺塔游戏
Mar 01 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实现过滤UBB代码的类
2015/03/12 PHP
Zend Framework框架中实现Ajax的方法示例
2017/06/27 PHP
tp5递归 无限级分类详解
2019/10/18 PHP
从Ajax到JQuery Ajax学习
2007/02/14 Javascript
发布一个基于javascript的动画类 Fx.js
2010/11/05 Javascript
js控制表单操作的常用代码小结
2013/08/15 Javascript
jquery通过a标签删除table中的一行的代码
2013/12/02 Javascript
jquery队列queue与原生模仿其实现方法分享
2014/03/25 Javascript
js对象内部访问this修饰的成员函数示例
2014/04/27 Javascript
iframe调用父页面函数示例详解
2014/07/17 Javascript
基于JS实现的倒计时程序实例
2015/07/24 Javascript
基于JS实现省市联动效果代码分享
2016/06/06 Javascript
JS实现动态增加和删除li标签行的实例代码
2016/10/16 Javascript
codeMirror插件使用讲解
2017/01/16 Javascript
Node.js 异步异常的处理与domain模块解析
2017/05/10 Javascript
Angular2 之 路由与导航详细介绍
2017/05/26 Javascript
Es6 Generator函数详细解析
2018/02/24 Javascript
JavaScript设计模式之责任链模式实例分析
2019/01/16 Javascript
JS继承定义与使用方法简单示例
2020/02/19 Javascript
vue动态渲染svg、添加点击事件的实现
2020/03/13 Javascript
JS字符串和数组如何实现相互转化
2020/07/02 Javascript
详解uniapp的全局变量实现方式
2021/01/11 Javascript
[02:57]2014DOTA2国际邀请赛-观众采访
2014/07/19 DOTA
[17:36]VG战队纪录片
2014/08/21 DOTA
[00:58]他们到底在电话里听到了什么?
2017/11/21 DOTA
深入了解Python数据类型之列表
2016/06/24 Python
Python自然语言处理之词干,词形与最大匹配算法代码详解
2017/11/16 Python
基于Python socket的端口扫描程序实例代码
2018/02/09 Python
pytorch 使用单个GPU与多个GPU进行训练与测试的方法
2019/08/19 Python
Numpy一维线性插值函数的用法
2020/04/22 Python
python将下载到本地m3u8视频合成MP4的代码详解
2020/11/24 Python
AmazeUI 点击元素显示全屏的实现
2020/08/25 HTML / CSS
优秀毕业自我鉴定
2014/02/15 职场文书
新年抽奖获奖感言
2014/03/02 职场文书
导师就业推荐信范文
2014/05/22 职场文书
节水标语大全
2014/06/11 职场文书