【爬虫 + 可视化】Python 爬取疫情并可视化处理数据(爬虫入门案例)

爬虫基本流程jsonrequests 爬虫当中 发送网络请求pandas 表格处理 / 保存数据pyecharts 可视化首先我们介绍一下什么是爬虫。什么是爬虫?网络爬虫是一种程序,主要用于搜索引擎,它将一个网站的所有内容与链接进行阅读,并建立相关的全文索引到数据库中,然后跳到另一个网站.样子好像一只大蜘蛛.
摘要由CSDN通过智能技术生成

知识点

  1. 爬虫基本流程

  2. json

  3. requests 爬虫当中 发送网络请求

  4. pandas 表格处理 / 保存数据

  5. pyecharts 可视化

首先我们介绍一下什么是爬虫。

什么是爬虫?

网络爬虫是一种程序,主要用于搜索引擎,它将一个网站的所有内容与链接进行阅读,并建立相关的全文索引到数据库中,然后跳到另一个网站.样子好像一只大蜘蛛.

当人们在网络上(如 google)搜索关键字时,其实就是比对数据库中的内容,找出与用户相符合的.网络爬虫程序的质量决定了搜索引擎的能力,如 google 的搜索引擎明显要比百度好,就是因为它的网络爬虫程序高效,编程结构好.可以这么简单的理解一下爬虫。即请求网站并且提取自己所需的数据的一个过程。至于怎么爬如何爬,将是后面进行学习的内容,暂且不必深究。通过我们的程序,可以代替我们向服务器发送请求,然后进行批量、大量的数据的下载。

我们再来看看爬虫的基本流程。

爬虫的基本流程

发起请求:通过 url 向服务器发起 request 请求,请求可以包含额外的 header 信息。

获取响应内容:如果服务器正常响应,那我们将会收到一个 response,response 即为我们所请求的网页内容,或许包含 HTML,Json 字符串或者二进制的数据(视频、图片)等。

解析内容:如果是 HTML 代码,则可以使用网页解析器进行解析,如果是 Json 数据,则可以转换成 Json 对象进行解析,如果是二进制的数据,则可以保存到文件进行进一步处理。

保存数据:可以保存到本地文件,也可以保存到数据库(MySQL,Redis,Mongodb 等)

在了解上面的基本内容后,我们通过爬取疫情数据来加深我们对爬虫概念的理解。

  1. 发送请求

  2. 获取数据 网页源代码

  3. 解析数据 筛选一些我想用的数据

  4. 保存数据 保存成表格

  5. 做数据可视化分析

爬虫完整代码

导入模块

import requests     # 第三方模块(发送请求)import re           # 正则import jsonimport csv

复制代码

然后我们需要选择我们的目标网址。

发送请求

url = 'https://voice.baidu.com/act/newpneumonia/newpneumonia/?from=osari_aladin_banner'response = requests.get(url=url, headers=headers)
  • 3
    点赞
  • 49
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个简单的Python爬虫数据分析案例: 首先,我们需要使用Python爬虫从网站上获数据。这里我们以豆瓣电影Top250为例,代码如下: ```python import requests from bs4 import BeautifulSoup url = 'https://movie.douban.com/top250' headers = { 'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/58.0.3029.110 Safari/537.36 Edge/16.16299' } def get_movie_list(url): movie_list = [] r = requests.get(url, headers=headers) soup = BeautifulSoup(r.text, 'html.parser') for i in soup.find_all('div', class_='info'): title = i.find('span', class_='title').get_text() rating = i.find('span', class_='rating_num').get_text() movie_list.append((title, rating)) return movie_list if __name__ == '__main__': movie_list = get_movie_list(url) print(movie_list) ``` 接下来,我们要对这些数据进行可处理。这里我们使用Matplotlib库来绘制柱状图和散点图。代码如下: ```python import matplotlib.pyplot as plt def draw_bar_chart(data): x = [i[0] for i in data] y = [float(i[1]) for i in data] plt.bar(x, y) plt.xticks(rotation=90) plt.show() def draw_scatter_chart(data): x = [i for i in range(len(data))] y = [float(i[1]) for i in data] plt.scatter(x, y) plt.xticks(x, [i[0] for i in data], rotation=90) plt.show() if __name__ == '__main__': movie_list = get_movie_list(url) draw_bar_chart(movie_list) draw_scatter_chart(movie_list) ``` 运行程序,我们就可以看到绘制出的柱状图和散点图了。这些图表可以帮助我们更直观地了解数据,以便进行后续分析。 注意:如果你想在 Jupyter Notebook 中实现交互式数据,可以考虑使用Python的另一个库Bokeh。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值