微信公众号:码农充电站pro

个人主页:https://codeshellme.github.io

在进行数据分析的时候,经常需要将数据进行可视化,以方便我们对数据的认识和理解。

0,Matplotlib 简介

Matplotlib 是一个可视化工具包,可以让我们使用Python 来可视化数据。

这里有一些官方资源你可以点击查看:

很多更高级的绘图库,也都是基于Matplotlib,比如seabornHoloViewsggplot 等。

在使用 Matplotlib 时,经常需要用到 pyplot 模块,用下面代码引入:

import matplotlib.pyplot as plt

下文中,都用plt 来代指pyplot

说明:

这里我们只介绍几种简单的图,更多其它的图,可以查看官方手册。

下面的每个函数,只介绍了最简单的用法,其它更多的参数可以查看手册。

1,散点图

plt.scatter 函数用于绘制散点图。函数原型:

scatter(x, y, s = None, c = None, marker = None)

参数含义:

  • x, y:分别表示点的横纵坐标。x, y 可以是单个点坐标,也可以是一组点坐标。
  • s:表示点的大小。
  • c:表示点的颜色。
  • marker:表示点的形状,可选的值见这里,比如 marker 的值为x, o, s等。

如下代码,画了三个点:

# 三个点的坐标分别是:
# (2, 5)
# (3,6)
# (3, 5)
plt.scatter([2, 3, 3], [5, 6, 5], marker='o')
plt.show() # 展示图

画出的散点图如下:

2,折线图

plt.plot 函数用于绘制折线图。函数原型:

plot(x, y)

参数 xy分别表示点的横纵坐标,一般是一组点坐标。

比如下面表格代表5 次数学考试成绩:

次数 1 2 3 4 5
成绩 89 78 92 79 86

将上面表格数据,绘制成折线图,代码如下:

x = [1, 2, 3, 4, 5]
y = [89, 78, 92, 79, 86]
plt.plot(x, y)
plt.show()

画出的折线图如下:

3,直方图

直方图用于描述数据的分布情况

plt.hist 函数用于绘制直方图。函数原型:

plt.hist(x, bins=None)

参数x是一个一维数组,bins 可以理解为矩形的个数,默认是10

假如下面是一次数学考试的成绩,全班共50 名同学:



将所有同学的成绩画成直方图,代码如下:

scores = [
96, 89, 95, 91, 94, 95, 92, 98, 95, 93,
93, 96, 94, 94, 98, 92, 88, 90, 88, 98,
84, 89, 87, 84, 94, 82, 83, 95, 93, 79,
84, 91, 86, 91, 81, 89, 77, 81, 77, 70,
66, 93, 90, 87, 79, 83, 86, 90, 93, 79,
]
plt.hist(scores)
plt.show()

画出来的直方图如下,横坐标为成绩区间,纵坐标为人数:

通过该直方图,可以直观的看出来每个成绩区间的人数。

4,条形图

plt.bar 函数用于绘制条形图。函数原型:

plt.bar(x, y, width = 0.8)

参数x, y 均是一个数组,x 是横坐标,表示数据类别;y 是纵坐标,表示每个类别的频度。参数width 表示长条的宽度。

比如下表是一位同学的期中考试的各科成绩:

我们将这位同学的成绩单画成条形图,代码如下:

# 每个科目分别用字母表示
subjects = ['A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I']
scores = [96, 89, 85, 91, 75, 90, 88, 79, 89]
plt.bar(subjects, scores)
plt.show()

画出的条形图如下:

5,饼图

饼图常用于表示个体占总体的占比情况。

plt.pie 函数用于绘制饼图。函数原型:

plt.pie(x, labels=None)

参数x是一个数组,表示一组数据,labels 用于描述每个数据的含义。

比如下表是某个公司某年每个季度的收入:

我们可以用饼图分析出每个季度占全年收入的占比,代码如下:

# 表示每个季度
quarters = ['1', '2', '3', '4']
incomes = [56, 89, 75, 91]
plt.pie(incomes, labels=quarters)
plt.show()

画出的饼图如下:

(本节完。)


推荐阅读:

决策树算法-理论篇-如何计算信息纯度

决策树算法-实战篇-鸢尾花及波士顿房价预测

朴素贝叶斯分类-理论篇-如何通过概率解决分类问题

朴素贝叶斯分类-实战篇-如何进行文本分类


欢迎关注作者公众号,获取更多技术干货。

如何使用Python 进行数据可视化的更多相关文章

  1. python爬虫+数据可视化项目(关注、持续更新)

    python爬虫+数据可视化项目(一) 爬取目标:中国天气网(起始url:http://www.weather.com.cn/textFC/hb.shtml#) 爬取内容:全国实时温度最低的十个城市气 ...

  2. Python:数据可视化pyecharts的使用

    什么是pyecharts? pyecharts 是一个用于生成 Echarts 图表的类库. echarts 是百度开源的一个数据可视化 JS 库,主要用于数据可视化.pyecharts 是一个用于生 ...

  3. Python - matplotlib 数据可视化

    在许多实际问题中,经常要对给出的数据进行可视化,便于观察. 今天专门针对Python中的数据可视化模块--matplotlib这块内容系统的整理,方便查找使用. 本文来自于对<利用python进 ...

  4. python爬虫28 | 你爬下的数据不分析一波可就亏了啊,使用python进行数据可视化

    通过这段时间 小帅b教你从抓包开始 到数据爬取 到数据解析 再到数据存储 相信你已经能抓取大部分你想爬取的网站数据了 恭喜恭喜 但是 数据抓取下来 要好好分析一波 最好的方式就是把数据进行可视化 这样 ...

  5. python的数据可视化库 matplotlib 和 pyecharts

    Matplotlib大家都很熟悉    不谈. ---------------------------------------------------------------------------- ...

  6. Python爬虫+数据可视化教学:分析猫咪交易数据

    猫猫这么可爱 不会有人不喜欢吧: 猫猫真的很可爱,和我女朋友一样可爱~你们可以和女朋友一起养一只可爱猫猫女朋友都有的吧?啊没有的话当我没说-咳咳网上的数据太多.太杂,而且我也不知道哪个网站的数据比较好 ...

  7. Python图表数据可视化Seaborn:3. 线性关系数据| 时间线图表| 热图

    1. 线性关系数据可视化 lmplot( ) import numpy as np import pandas as pd import matplotlib.pyplot as plt import ...

  8. Python图表数据可视化Seaborn:2. 分类数据可视化-分类散点图|分布图(箱型图|小提琴图|LV图表)|统计图(柱状图|折线图)

    1. 分类数据可视化 - 分类散点图 stripplot( ) / swarmplot( ) sns.stripplot(x="day",y="total_bill&qu ...

  9. Python图表数据可视化Seaborn:1. 风格| 分布数据可视化-直方图| 密度图| 散点图

    conda  install seaborn  是安装到jupyter那个环境的 1. 整体风格设置 对图表整体颜色.比例等进行风格设置,包括颜色色板等调用系统风格进行数据可视化 set() / se ...

随机推荐

  1. STM32入门系列-GPIO结构

    已经了解了STM32 GPIO的基本概念及引脚分类.现在来看下STM32 GPIO内部的结构是怎样的.IO端口位的基本结构如下图所示. 从图中可以看出GPIO内部结构还是比较复杂的,只要将这张GPIO ...

  2. 计算机网络:TCP协议建立连接的过程为什么是三次握手而不是两次?【对于网上的两种说法我的思考】

    网上关于这个问题吵得很凶,但是仔细看过之后我更偏向认为两种说的是一样的. 首先我们来看看 TCP 协议的三次握手过程 如上图所示: 解释一下里面的英文: 里面起到作用的一些标志位就是TCP报文首部里的 ...

  3. WC2019 填坑记

    2019年1月8日 1.Luogu P2147 [SDOI2008]洞穴勘测 (LCT模板题&LCT学习) 2019年1月9日 2.LuoguP3203 [HNOI2010]弹飞绵羊  (LC ...

  4. Java集合(类)框架(三)

    1. Map集合 相较于List和Set集合而言,Map集合所储存的数据为双列行,数据是以key和value为一个单位进行存储的,如在建立一个学生Map的时候,其中的数据应为 学号-姓名(key-va ...

  5. Java并发队列与容器

    [前言:无论是大数据从业人员还是Java从业人员,掌握Java高并发和多线程是必备技能之一.本文主要阐述Java并发包下的阻塞队列和并发容器,其实研读过大数据相关技术如Spark.Storm等源码的, ...

  6. js——事件循环

    JS-事件循环 js运行的环境称之为宿主环境. 执行栈 :call stack ,一个数据结构,用于存放各种函数的执行环境,每一个函数执行之前他的相关信息会加入到执行栈中,函数调用之前,创建执行环境, ...

  7. apache+php安装

    https://codebriefly.com/how-to-setup-apache-php-mysql-on-windows-10/ 出问题的地方 1.apache rewrite 模块开启 (去 ...

  8. python爬虫10 b站爬取使用 selenium+ phantomJS

    但有时候 我们不想要让它打开浏览器去执行 能不能直接在代码里面运行呢 也就是说 有没有一个无形的浏览器呢 恩 phantomJS 就是 它是一个基于 WebKit 的浏览器引擎 可以做到无声无息的操作 ...

  9. ubuntu12.04管理文件系统工具

    ubuntu12.04管理文件系统工具 以前可以自动管理系统盘和移动硬盘,刚重新安装了UBUNTU12.04LTS之后不行了,原来是这个工具: "PCMANFM" 群星_-_偏偏喜 ...

  10. 睿象云:为什么 Zabbix 告警如此火热?

    每当我们谈及监控工具的时候,Zabbix 总是最惹人瞩目的那一个.如同清晨荷叶上的剔透露珠,卓尔不凡:如同巷子末头的百年酒香,让人倾心.我们都知道 Zabbix 是监控工具里当仁不让的龙头大哥,却没几 ...