如何使用Python 进行数据可视化
微信公众号:码农充电站pro
个人主页:https://codeshellme.github.io
在进行数据分析的时候,经常需要将数据进行可视化,以方便我们对数据的认识和理解。
0,Matplotlib 简介
Matplotlib 是一个可视化工具包,可以让我们使用Python 来可视化数据。
这里有一些官方资源你可以点击查看:
- Matplotlib 安装
- Matplotlib 用户手册
- Matplotlib 函数汇总
- Matplotlib 模块索引
- Matplotlib 示例库
- Matplotlib 示例下载
很多更高级的绘图库,也都是基于Matplotlib,比如seaborn,HoloViews,ggplot 等。
在使用 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)
参数 x
,y
分别表示点的横纵坐标,一般是一组点坐标。
比如下面表格代表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 进行数据可视化的更多相关文章
- python爬虫+数据可视化项目(关注、持续更新)
python爬虫+数据可视化项目(一) 爬取目标:中国天气网(起始url:http://www.weather.com.cn/textFC/hb.shtml#) 爬取内容:全国实时温度最低的十个城市气 ...
- Python:数据可视化pyecharts的使用
什么是pyecharts? pyecharts 是一个用于生成 Echarts 图表的类库. echarts 是百度开源的一个数据可视化 JS 库,主要用于数据可视化.pyecharts 是一个用于生 ...
- Python - matplotlib 数据可视化
在许多实际问题中,经常要对给出的数据进行可视化,便于观察. 今天专门针对Python中的数据可视化模块--matplotlib这块内容系统的整理,方便查找使用. 本文来自于对<利用python进 ...
- python爬虫28 | 你爬下的数据不分析一波可就亏了啊,使用python进行数据可视化
通过这段时间 小帅b教你从抓包开始 到数据爬取 到数据解析 再到数据存储 相信你已经能抓取大部分你想爬取的网站数据了 恭喜恭喜 但是 数据抓取下来 要好好分析一波 最好的方式就是把数据进行可视化 这样 ...
- python的数据可视化库 matplotlib 和 pyecharts
Matplotlib大家都很熟悉 不谈. ---------------------------------------------------------------------------- ...
- Python爬虫+数据可视化教学:分析猫咪交易数据
猫猫这么可爱 不会有人不喜欢吧: 猫猫真的很可爱,和我女朋友一样可爱~你们可以和女朋友一起养一只可爱猫猫女朋友都有的吧?啊没有的话当我没说-咳咳网上的数据太多.太杂,而且我也不知道哪个网站的数据比较好 ...
- Python图表数据可视化Seaborn:3. 线性关系数据| 时间线图表| 热图
1. 线性关系数据可视化 lmplot( ) import numpy as np import pandas as pd import matplotlib.pyplot as plt import ...
- Python图表数据可视化Seaborn:2. 分类数据可视化-分类散点图|分布图(箱型图|小提琴图|LV图表)|统计图(柱状图|折线图)
1. 分类数据可视化 - 分类散点图 stripplot( ) / swarmplot( ) sns.stripplot(x="day",y="total_bill&qu ...
- Python图表数据可视化Seaborn:1. 风格| 分布数据可视化-直方图| 密度图| 散点图
conda install seaborn 是安装到jupyter那个环境的 1. 整体风格设置 对图表整体颜色.比例等进行风格设置,包括颜色色板等调用系统风格进行数据可视化 set() / se ...
随机推荐
- Java学习的第五天
1.值域转化的规则:值域小的类型可以自动转化成值域大的类型,值域大的类型可以强行转化成值域小的类型,但要注意精度,除了基本类型可以转换,引用类型之间也可以转换. 引用类型可以是类,借口,数组. 常见的 ...
- glog修改
在写代码的过程中,打log肯定是少不了的,毕竟不能总靠调试来发现问题.log库的选用就很纠结了,成熟的log库非常多,log4cpp.log4cxx.poco.log.boost.log.glog等等 ...
- react 实现组件嵌套以及子组件与父组件之间的通信
当子组件触发onChange事件时,实际调用的是父组件中的handelSelect函数,通俗来说就是父组件通过属性handleSelect实现与子组件之间的通信. 父组件:SignupForm 子组件 ...
- css 背景图片自适应分辨率大小 兼容
拉伸,all浏览器兼容.bg{ background:url(http://wyz.67ge.com/wp-content/uploads/qzlogo.jpg); filter:&q ...
- 内网渗透 day12-免杀框架2
免杀框架2 目录 1. IPC管道连接 2. 查看wifi密码 3. Phantom-Evasion免杀框架的运用 4. 自解压(sfx) 5. 数字签名 6. 资源替换 1. IPC管道连接 命名管 ...
- [MIT6.006] 8. Hashing with Chaining 散列表
一.字典 在之前课里,如果我们要实现插入,删除和查找,使用树结构,最好的时间复杂度是AVL下的Ο(log2n),使用线性结构,最好的复杂度为基数排序Ο(n).但如果使用字典数据类型去做,时间复杂度可为 ...
- high Performance
目的 找出系统性能瓶颈(包括硬件瓶颈和软件瓶颈): 提供性能优化的方案(升级硬件?改进系统系统结构?): 达到合理的硬件和软件配置: 使系统资源使用达到最大的平衡. CPU过渡使用会造成大量进程等待C ...
- 1. 线性DP 300. 最长上升子序列 (LIS)
最经典单串: 300. 最长上升子序列 (LIS) https://leetcode-cn.com/problems/longest-increasing-subsequence/submission ...
- Linux配置邮件发送信息
背景 一般情况下,我们的IT系统都会有相关的告警的处理,有的是邮件,有的是短信,这些都能很方便的获得一些有用的信息 在某些时候我们没有这样的系统,而自己又需要定期的获取一些信息的时候,配置一个邮件发送 ...
- bWAPP----HTML OS Command Injection - Blind
OS Command Injection - Blind 先上代码,他判断了win还是linux然后进行了ping但是结果并没有返回. 1 <div id="main"> ...