python数据可视化的3大步骤,你知道吗?(代码片段)

Wang_AI Wang_AI     2022-11-29     367

关键词:

Python实现可视化的三个步骤:

  • 确定问题,选择图形

  • 转换数据,应用函数

  • 参数设置,一目了然

1、首先,要知道我们用哪些库来画图?

matplotlib

Python中最基本的作图库就是matplotlib,是一个最基础的Python可视化库,一般都是从matplotlib上手Python数据可视化,然后开始做纵向与横向拓展。

Seaborn

是一个基于matplotlib的高级可视化效果库,针对的点主要是数据挖掘和机器学习中的变量特征选取,seaborn可以用短小的代码去绘制描述更多维度数据的可视化效果图

其他库还包括

Bokeh(是一个用于做浏览器端交互可视化的库,实现分析师与数据的交互);Mapbox(处理地理数据引擎更强的可视化工具库)等等

本篇文章主要使用matplotlib进行案例分析

第一步:确定问题,选择图形

业务可能很复杂,但是经过拆分,我们要找到我们想通过图形表达什么具体问题。分析思维的训练可以学习《麦肯锡方法》和《金字塔原理》中的方法。

这是网上的一张关于图表类型选择的总结。

在Python中,我们可以总结为以下四种基本视觉元素来展现图形:

  • :scatter plot 二维数据,适用于简单二维关系;

  • 线:line plot 二维数据,适用于时间序列;

  • 柱状:bar plot 二维数据,适用于类别统计;

  • 颜色:heatmap 适用于展示第三维度;

数据间存在分布,构成,比较,联系以及变化趋势等关系。对应不一样的关系,选择相应的图形进行展示。

第二步:转换数据,应用函数

数据分析和建模方面的大量编程工作都是用在数据准备的基础上的:加载、清理、转换以及重塑。我们可视化步骤也需要对数据进行整理,转换成我们需要的格式再套用可视化方法完成作图。

下面是一些常用的数据转换方法:

  • 合并:merge,concat,combine_frist(类似于数据库中的全外连接)

  • 重塑:reshape;轴向旋转:pivot(类似excel数据透视表)

  • 去重:drop_duplicates

  • 映射:map

  • 填充替换:fillna,replace

  • 重命名轴索引:rename

将分类变量转换‘哑变量矩阵’的get_dummies函数以及在df中对某列数据取限定值等等。

函数则根据第一步中选择好的图形,去找Python中对应的函数。

第三步:参数设置,一目了然

原始图形画完后,我们可以根据需求修改颜色(color),线型(linestyle),标记(maker)或者其他图表装饰项标题(Title),轴标签(xlabel,ylabel),轴刻度(set_xticks),还有图例(legend)等,让图形更加直观。

第三步是在第二步的基础上,为了使图形更加清晰明了,做的修饰工作。具体参数都可以在制图函数中找到。

2、可视化作图基础

Matplotlib作图基础

#导入包
import numpy as np
import pandas as pd
import matplotlib.pyplot as plt

Figure和Subplot

matplotlib的图形都位于Figure(画布)中,Subplot创建图像空间。不能通过figure绘图,必须用add_subplot创建一个或多个subplot。

figsize可以指定图像尺寸。

#创建画布
fig = plt.figure()
<Figure size 432x288 with 0 Axes>
#创建subplot,221表示这是2行2列表格中的第1个图像。
ax1 = fig.add_subplot(221)
#但现在更习惯使用以下方法创建画布和图像,2,2表示这是一个2*2的画布,可以放置4个图像
fig , axes = plt.subplots(2,2,sharex=True,sharey=True)
#plt.subplot的sharex和sharey参数可以指定所有的subplot使用相同的x,y轴刻度。

利用Figure的subplots_adjust方法可以调整间距。

subplots_adjust(left=None,bottom=None,right=None,top=None,wspace=None,hspace=None)

颜色color,标记marker,和线型linestyle

matplotlib的plot函数接受一组X和Y坐标,还可以接受一个表示颜色和线型的字符串缩写:'g--',表示颜色是绿色green,线型是'--'虚线。也可以使用参数明确的指定。

线型图还可以加上一些标记(marker),来突出显示数据点的位置。标记也可以放在格式字符串中,但标记类型和线型必须放在颜色后面。


 
plt.plot(np.random.randn(30),color='g',linestyle='--',marker='o')
[<matplotlib.lines.Line2D at 0x8c919b0>]

刻度,标签和图例

plt的xlim、xticks和xtickslabels方法分别控制图表的范围和刻度位置和刻度标签。

调用方法时不带参数,则返回当前的参数值;调用时带参数,则设置参数值。


 
plt.plot(np.random.randn(30),color='g',linestyle='--',marker='o')
plt.xlim() #不带参数调用,显示当前参数;
#可将xlim替换为另外两个方法试试
(-1.4500000000000002, 30.45)

plt.plot(np.random.randn(30),color='g',linestyle='--',marker='o')
plt.xlim([0,15]) #横轴刻度变成0-15
(0, 15)

设置标题,轴标签,刻度以及刻度标签


 
fig = plt.figure();ax = fig.add_subplot(1,1,1)
ax.plot(np.random.randn(1000).cumsum())
ticks = ax.set_xticks([0,250,500,750,1000]) #设置刻度值
labels = ax.set_xticklabels(['one','two','three','four','five']) #设置刻度标签
ax.set_title('My first Plot') #设置标题
ax.set_xlabel('Stage') #设置轴标签
Text(0.5,0,'Stage')

添加图例

图例legend是另一种用于标识图标元素的重要工具。可以在添加subplot的时候传入label参数。


 
fig = plt.figure(figsize=(12,5));ax = fig.add_subplot(111)
ax.plot(np.random.randn(1000).cumsum(),'k',label='one') #传入label参数,定义label名称
ax.plot(np.random.randn(1000).cumsum(),'k--',label='two')
ax.plot(np.random.randn(1000).cumsum(),'k.',label='three')
#图形创建完后,只需要调用legend参数将label调出来即可。
ax.legend(loc='best') #要求不是很严格的话,建议使用loc=‘best’参数来让它自己选择最佳位置
<matplotlib.legend.Legend at 0xa8f5a20>

注解

除标准的图表对象之外,我们还可以自定义添加一些文字注解或者箭头。

注解可以通过text,arrow和annotate等函数进行添加。text函数可以将文本绘制在指定的x,y坐标位置,还可以进行自定义格式

plt.plot(np.random.randn(1000).cumsum())
plt.text(600,10,'test ',family='monospace',fontsize=10)
#中文注释在默认环境下并不能正常显示,需要修改配置文件,使其支持中文字体。具体步骤请自行搜索。

保存图表到文件

利用plt.savefig可以将当前图表保存到文件。例如,要将图表保存为png文件,可以执行

文件类型是根据拓展名而定的。其他参数还有:

  • fname:含有文件路径的字符串,拓展名指定文件类型

  • dpi:分辨率,默认100 facecolor,edgcolor 图像的背景色,默认‘w’白色

  • format:显示设置文件格式('png','pdf','svg','ps','jpg'等)

  • bbox_inches:图表需要保留的部分。如果设置为“tight”,则将尝试剪除图像周围的空白部分


 
plt.savefig('./plot.jpg') #保存图像为plot名称的jpg格式图像
<Figure size 432x288 with 0 Axes>

3、Pandas中的绘图函数

Matplotlib作图

matplotlib是最基础的绘图函数,也是相对较低级的工具。组装一张图表需要单独调用各个基础组件才行。Pandas中有许多基于matplotlib的高级绘图方法,原本需要多行代码才能搞定的图表,使用pandas只需要短短几行。

我们使用的就调用了pandas中的绘图包。

import matplotlib.pyplot as plt

线型图

Series和DataFrame都有一个用于生成各类图表的plot方法。默认情况下,他们生成的是线型图。

s = pd.Series(np.random.randn(10).cumsum(),index=np.arange(0,100,10))
s.plot() #Series对象的索引index会传给matplotlib用作绘制x轴。
<matplotlib.axes._subplots.AxesSubplot at 0xf553128>


 
df = pd.DataFrame(np.random.randn(10,4).cumsum(0),columns=['A','B','C','D'])
df.plot() #plot会自动为不同变量改变颜色,并添加图例
<matplotlib.axes._subplots.AxesSubplot at 0xf4f9eb8>

Series.plot方法的参数

  • label:用于图表的标签

  • style:风格字符串,'g--'

  • alpha:图像的填充不透明度(0-1)

  • kind:图表类型(bar,line,hist,kde等)

  • xticks:设定x轴刻度值

  • yticks:设定y轴刻度值

  • xlim,ylim:设定轴界限,[0,10]

  • grid:显示轴网格线,默认关闭

  • rot:旋转刻度标签

  • use_index:将对象的索引用作刻度标签

  • logy:在Y轴上使用对数标尺

DataFrame.plot方法的参数

DataFrame除了Series中的参数外,还有一些独有的选项。

  • subplots:将各个DataFrame列绘制到单独的subplot中

  • sharex,sharey:共享x,y轴

  • figsize:控制图像大小

  • title:图像标题

  • legend:添加图例,默认显示

  • sort_columns:以字母顺序绘制各列,默认使用当前顺序

柱状图

在生成线型图的代码中加上kind=‘bar’或者kind=‘barh’,可以生成柱状图或水平柱状图。


 
fig,axes = plt.subplots(2,1)
data = pd.Series(np.random.rand(10),index=list('abcdefghij'))
data.plot(kind='bar',ax=axes[0],rot=0,alpha=0.3)
data.plot(kind='barh',ax=axes[1],grid=True)
<matplotlib.axes._subplots.AxesSubplot at 0xfe39898>

柱状图有一个非常实用的方法:

利用value_counts图形化显示Series或者DF中各值的出现频率。

比如df.value_counts().plot(kind='bar')

Python可视化的基础语法就到这里,其他图形的绘制方法大同小异。

重点是遵循三个步骤的思路来进行思考、选择、应用。多多练习可以更加熟练。

文章来源:数据分析1480

当.net撞上bi可视化,这3种“套路”你必须知道(代码片段)

...目,直接做BI大屏过于复杂,所以想直接集成使用BI数据可视化分析大屏。所以,这次我们就从——Wyn出发,为大家介绍如何在.Net环境中集成BI仪表板数据可视化大屏。说到这里有些同学对BI仪表板数据可视化大屏并没有概念,我... 查看详情

0基础大数据编程怎么学?三个步骤+加一套完整学习体系教你入门

对于零基础的朋友,一开始入门可能不会太简单。大数据零基础怎么学?大数据零基础学什么?难吗?要学习大数据你至少应该知道什么是大数据,大数据一般运用在什么领域。对大数据有一个大概的了解,你才能清楚自己对大数... 查看详情

如何在windows电脑上下载python这几个步骤你知道吗

参考技术A1、首先需要到python的官网上下载安装包,然后点击安装,选择默认安装路径,然后一直下一步下一步即可。2、单击左下角的开始菜单,然后右键点击【计算机】,选择【属性】这个选项。3、点击【属性】进入后选择... 查看详情

毕业设计大数据全国疫情数据分析与3d可视化-python大数据(代码片段)

...#xff0c;今天要分享的是🚩大数据全国疫情数据分析与3D可视化🥇学长这里给一个题目综合评分(每项满分5分)难度系数:2分工作量:3分创新点:4分🧿选题指导,项目分享:https://gitee.com/dancheng-senior/project-... 查看详情

毕业设计大数据全国疫情数据分析与3d可视化-python大数据(代码片段)

...#xff0c;今天要分享的是🚩大数据全国疫情数据分析与3D可视化🥇学长这里给一个题目综合评分(每项满分5分)难度系数:2分工作量:3分创新点:4分🧿选题指导,项目分享:https://gitee.com/dancheng-senior/project-... 查看详情

毕业设计python+大数据构建疫情可视化分析系统(代码片段)

...章目录0前言1课题介绍2运行效果3关键代码3.1数据爬虫3.2可视化部分4最后0前言🔥这两年开始毕业设计和毕业答辩的要求和难度不断提升,传统的毕设题目缺少创新和亮点,往往达不到毕业答辩的要求,这两年不断... 查看详情

你知道如何将python中嵌套的列表扁平化吗?(代码片段)

楔子将python中嵌套的列表扁平化,指的就是:lst=[1,[[[[3,3],5]]],[[[[[[[[[[[[[6]]]]],8]]],"aaa"]]]],250]]#类似于上面的列表,我们要得到下面的结果[1,3,3,5,6,8,"aaa",250]那么我们要如何做呢?yield和yieldfrom关于如何把一个嵌套的... 查看详情

学习大数据分析要用到哪些知识?

...提高数据库的安全性是非常有必要的。3.掌握数据整理、可视化和报表制作数据整理,是将原始数据转换成方便实用的格式,实用工具有Excel、R、Python等工具。数据可视化,是创建和研究数据的视觉表现,方便业务方快速分析数... 查看详情

大数据具体有哪些类型你知道吗

  对于大部分人来讲,大数据离我们的生活还是很遥远的,但它的威力却已经无处不在了。如今,我们只有理解大数据并借助其优势做出决策,才能发挥它的巨大作用。今天就由千锋大数据开发培训的讲师来为大家讲一下大数... 查看详情

大数据应用的几个阶段?你知道吗?

大数据目的在于?从庞杂的数据背后挖掘、分析用户的行为习惯和喜好,找出更符合用户【口味】的产品和服务并结合用户需求有针对性地调整和优化自身,就是大数据的价值。对于大数据在商业上的用途,了解用户的行为习惯... 查看详情

大数据必修三大技能,你知道吗?

大数据,人工智能技术引领科技潮流,推开大数据时代的大门!国家点赞!政策扶持,前景斐然!紧接着,学习大数据的人才便如过江之鲫,络绎不绝!整体形势,欣欣向荣!在这里,小编为大家送上技术干货,助大家一臂之力... 查看详情

python毕业设计抖音短视频数据分析与可视化-python大数据可视化(代码片段)

文章目录0前言1课题背景2数据清洗3数据可视化地区-用户观看时间分界线每周观看观看路径发布地点视频时长整体点赞、完播4进阶分析相关性分析留存率5深度分析客户价值判断0前言🔥这两年开始毕业设计和毕业答辩的要求... 查看详情

毕业设计基于大数据的抖音短视频数据分析与可视化-python大数据可视化(代码片段)

文章目录0前言1课题背景2数据清洗3数据可视化地区-用户观看时间分界线每周观看观看路径发布地点视频时长整体点赞、完播4进阶分析相关性分析留存率5深度分析客户价值判断5最后0前言🔥这两年开始毕业设计和毕业答辩的... 查看详情

python就业方向都有哪些呀?适合小白学习吗

...,比如,"大数据"分析所需要的分布式计算、数据可视化、数据库操作等,都可以通过Python中的十分成熟的模块完成。想了解更多Python相关,可转:参考技术A整理了Python的7大就业方向,希望大家能找到适合自己的,然后... 查看详情

主成分分析(pca)及其可视化——python(代码片段)

...了python可以看看matlab的哦主成分分析(PCA)及其可视化——matlab_菜菜笨小孩的博客-CSDN博客目录一、主成分分析的原理二、主成分分析步骤1.主成分分析的步骤:2.部分说明(1)球形检验(Bartlett)(2... 查看详情

图表控件,数据可视化,你真的选对了吗?

数据可视化主要是借助图形化的方法,清晰有效的展示数据,让关系繁杂的数据变得一目了然,大数据量呈现变得明显,数据内在关系变得明确清晰。一般数据可视化库包含2DXY图表,3DXYZ图表,极坐标图,史密斯圆图,GIS地图等... 查看详情

phoneclean还可以这样恢复数据,你知道吗?

...除系统垃圾,但是误操作是存在的,如何快速恢复删除的数据呢?小编总结了几种方法,是否对您有所帮助呢一起来看看~[dl]15-571[/dl]PhoneClean还可以这样恢复数据你知道吗步骤1:准备工作。1、在计算机上运行PhoneClean2、通过USB电... 查看详情

毕业设计大数据b站数据分析与可视化-python数据分析大数据(代码片段)

文章目录0前言1课题背景2实现效果3数据获取4数据可视化5最后0前言🔥这两年开始毕业设计和毕业答辩的要求和难度不断提升,传统的毕设题目缺少创新和亮点,往往达不到毕业答辩的要求,这两年不断有学弟学... 查看详情