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 相关文章推荐
python实现系统状态监测和故障转移实例方法
Nov 18 Python
简单介绍Python中的readline()方法的使用
May 24 Python
Python多进程机制实例详解
Jul 02 Python
Tensorflow 训练自己的数据集将数据直接导入到内存
Jun 19 Python
Python中反射和描述器总结
Sep 23 Python
解决python opencv无法显示图片的问题
Oct 28 Python
设置python3为默认python的方法
Oct 31 Python
django项目中使用手机号登录的实例代码
Aug 15 Python
python中resample函数实现重采样和降采样代码
Feb 25 Python
如何解决python多种版本冲突问题
Oct 13 Python
秀!学妹看见都惊呆的Python小招数!【详细语言特性使用技巧】
Apr 27 Python
Python 的 sum() Pythonic 的求和方法详细
Oct 16 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源码分析之变量的存储过程分解
2014/07/03 PHP
使用array_map简单搞定PHP删除文件、删除目录
2014/10/29 PHP
PHP模板引擎Smarty内建函数foreach,foreachelse用法分析
2016/04/11 PHP
thinkphp,onethink和thinkox中验证码不显示的解决方法分析
2016/06/06 PHP
PHP实现链式操作的原理详解
2016/09/16 PHP
用ADODB.Stream转换
2007/01/22 Javascript
基于jquery编写的横向自适应幻灯片切换特效的实例代码
2013/08/06 Javascript
javascript操作字符串的原生方法
2014/12/22 Javascript
jQuery实现给页面换肤的方法
2015/05/30 Javascript
js实现select跳转菜单新窗口效果代码分享(超简单)
2015/08/21 Javascript
浅谈jquery的map()和each()方法
2016/06/12 Javascript
JavaScript实现相册弹窗功能(zepto.js)
2016/06/21 Javascript
vue.js入门教程之基础语法小结
2016/09/01 Javascript
微信小程序技巧之show内容展示,上传文件编码问题
2017/01/23 Javascript
node.JS md5加密中文与php结果不一致的解决方法
2017/05/05 Javascript
详解Vue.directive 自定义指令
2019/03/27 Javascript
小程序rich-text组件如何改变内部img图片样式的方法
2019/05/22 Javascript
JavaScript函数重载操作实例浅析
2020/05/02 Javascript
利用python批量检查网站的可用性
2016/09/09 Python
在 Python 应用中使用 MongoDB的方法
2017/01/05 Python
python自动登录12306并自动点击验证码完成登录的实现源代码
2018/04/25 Python
Python Selenium 之数据驱动测试的实现
2019/08/01 Python
Python datetime包函数简单介绍
2019/08/28 Python
Python常用模块sys,os,time,random功能与用法实例分析
2020/01/07 Python
Python类中self参数用法详解
2020/02/13 Python
基于TensorBoard中graph模块图结构分析
2020/02/15 Python
django 解决扩展自带User表遇到的问题
2020/05/14 Python
很酷的小工具和电子产品商城:GearBest
2016/11/19 全球购物
锐步英国官网:Reebok英国
2019/11/29 全球购物
类成员函数的重载、覆盖和隐藏区别
2016/01/27 面试题
知识竞赛活动方案
2014/02/18 职场文书
募捐倡议书
2014/04/14 职场文书
奉献爱心演讲稿
2014/09/04 职场文书
婚内房产协议书范本
2014/10/02 职场文书
职工年度考核评语
2014/12/31 职场文书
你为什么是穷人?可能是这5个缺点造成
2019/07/11 职场文书