CDA数据分析师 出品
作者:Frank Andrade
编译:Mika
作为一名数据工作者,我特别喜欢用Python创建美观且易懂的可视化图表,而且技术难度小,不会花费大量时间。
交互式可视化也是如此,因此我花了很长时间寻找Python中好用的库。能创建交互式可视化图表的库有很多,但当使用Pandas时,很容易遇到各种各样的问题。
今天,我就来手把手教你如何直接使用Pandas创建出交互式可视化效果。
为了轻松创建交互式可视化,我们需要安装Cufflinks。这是一个将Pandas与Plotly连接起来的库,从而我们能够直接从Pandas创建可视化效果。
首先,确保安装Pandas并在终端上运行以下命令:
pip install pandas
pip install plotly
注意,你也可以使用conda安装Plotly
conda install -c plotly
安装 Plotly 后,运行以下命令安装 Cufflinks:
pip install cufflinks
接下来要导入以下库:
import pandas as pd
import cufflinks as cf
from IPython.display import display,HTMLcf.set_config_file(sharing='public',theme='ggplot',offline=True)
在这里,我用的是 ‘ggplot’ 主题,你也可以随意选择任何想要的主题。运行命令 cf.getThemes() 以获取所有可用的主题。
要在以下部分中使用 Pandas 进行交互式可视化,我们只需要使用语法 dataframe.iplot()
在本文中,我们将使用人口数据框。
“CDA数据分析师”公众号后台回复关键字 “人口” ,
即可下载数据CSV 文件。
下载文件后,移动到 Python 脚本所在的位置,然后在 Pandas 数据框中进行读取,如下所示。
df_population = pd.read_csv('population_total.csv')
数据框中包含了世界上大多数国家多年来的人口数据,如下所示:
在使用之前,我们需要对其进行处理,删除空值,重新调整,然后选择几个国家来测试交互式绘图。
代码如下:
# dropping null values
df_population = df_population.dropna()# reshaping the dataframe
df_population = df_population.pivot(index='year', columns='country',
values='population')# selecting 5 countries
df_population = df_population[['United States', 'India', 'China',
'Indonesia', 'Brazil']]
现在数据框如下图所示,可以进行绘图了。
下面让我们做一个折线图来,对其中5 个国家在 1955 年到 2020 年的人口增长量进行对比。
如前所述,我们将使用语法 df_population.iplot(kind=‘name_of_plot’) 来进行绘制。如下所示:
df_population.iplot(kind='line',xTitle='Years', yTitle='Population',
title='Population (1955-2020)')
一眼就可以看到,印度的人口增长速度比其他国家快。
单条形图
让我们创建一个条形图,显示2020年前每个国家的人口。
首先,我们从索引中选择2020年,然后将行与列转换,以获得列中的年份。将这个新的数据框命名为 df_population_2020 。我们将在绘制饼图时将再次使用这个数据框。
df_population_2020 = df_population[df_population.index.isin([2020])]
df_population_2020 = df_population_2020.T
现在我们可以用 .iplot() 来对新数据框进行绘制. 在这种情况下,我将使用颜色参数将条形颜色设置为浅绿色。
df_population_2020.iplot(kind='bar', color='lightgreen',
xTitle='Years', yTitle='Population',
title='Population in 2020')
多个变量分组的条形图
现在让我们看看不同年代初期人口的变化情况。
# filter years out
df_population_sample = df_population[df_population.index.isin([1980, 1990, 2000, 2010, 2020])]# plotting
df_population_sample.iplot(kind='bar', xTitle='Years',
yTitle='Population')
多年来,这些国家的人口都在增长,但有些国家的增长速度更快。
箱形图
当我们想查看数据的分布时,箱线图就派上用场了。箱线图将显示最小值、第一四分位数 (Q1)、中位数、第三个四分位数 (Q3)以及 最大值。查看这些值的最简单方法是创建交互式可视化。
接着让我们看到美国的人口分布。
df_population['United States'].iplot(kind='box', color='green',
yTitle='Population')
我们还可以看到其他国家或地区的人口分布。
df_population.iplot(kind='box', xTitle='Countries',
yTitle='Population')
如我们所见,我们还可以通过点击右侧的图例来过滤掉任何国家。
直方图表示数值数据的分布。让我们看看美国和印度尼西亚的人口分布。
df_population[['United States', 'Indonesia']].iplot(kind='hist',
xTitle='Population')
饼图
让我们用饼图来比较一下 2020 年的人口。为此,我们将使用在单个条形图部分中创建的数据框 df_population_2020
注意,要制作饼图,我们需要将“国家/地区”作为列而不是索引,因此我们使用 .reset_index() 来获取列。然后我们将其 2020 转换为字符串。
# transforming data
df_population_2020 = df_population_2020.reset_index()
df_population_2020 =df_population_2020.rename(columns={2020:'2020'})# plotting
df_population_2020.iplot(kind='pie', labels='country',
values='2020',
title='Population in 2020 (%)')
其实人口数据不适合用散点图,但出于演示的目的,这里还是列举出来了。
df_population.iplot(kind='scatter', mode='markers')
以上就是本文的全部内容了。不妨下载数据来试试,用Pandas来绘制文中提到的交互式可视化吧!
“CDA数据分析师”公众号后台回复关键字 “人口” ,
即可下载数据CSV 文件。
还想学习哪方面的内容,也欢迎在评论区给我们留言哦~
数据分析咨询请扫描二维码
若不方便扫码,搜微信号:CDAshujufenxi
在当今数字化时代,数据分析师的重要性与日俱增。但许多人在踏上这条职业道路时,往往充满疑惑: 如何成为一名数据分析师?成为 ...
2025-04-02最近我发现一个绝招,用DeepSeek AI处理Excel数据简直太爽了!处理速度嘎嘎快! 平常一整天的表格处理工作,现在只要三步就能搞 ...
2025-04-01你是否被统计学复杂的理论和晦涩的公式劝退过?别担心,“山有木兮:统计学极简入门(Python)” 将为你一一化解这些难题。课程 ...
2025-03-31在电商、零售、甚至内容付费业务中,你真的了解你的客户吗? 有些客户下了一两次单就消失了,有些人每个月都回购,有些人曾经是 ...
2025-03-31在数字化浪潮中,数据驱动决策已成为企业发展的核心竞争力,数据分析人才的需求持续飙升。世界经济论坛发布的《未来就业报告》, ...
2025-03-28你有没有遇到过这样的情况?流量进来了,转化率却不高,辛辛苦苦拉来的用户,最后大部分都悄无声息地离开了,这时候漏斗分析就非 ...
2025-03-27TensorFlow Datasets(TFDS)是一个用于下载、管理和预处理机器学习数据集的库。它提供了易于使用的API,允许用户从现有集合中 ...
2025-03-26"不谋全局者,不足谋一域。"在数据驱动的商业时代,战略级数据分析能力已成为职场核心竞争力。《CDA二级教材:商业策略数据分析 ...
2025-03-26当你在某宝刷到【猜你喜欢】时,当抖音精准推来你的梦中情猫时,当美团外卖弹窗刚好是你想吃的火锅店…… 恭喜你,你正在被用户 ...
2025-03-26当面试官问起随机森林时,他到底在考察什么? ""请解释随机森林的原理""——这是数据分析岗位面试中的经典问题。但你可能不知道 ...
2025-03-25在数字化浪潮席卷的当下,数据俨然成为企业的命脉,贯穿于业务运作的各个环节。从线上到线下,从平台的交易数据,到门店的运营 ...
2025-03-25在互联网和移动应用领域,DAU(日活跃用户数)是一个耳熟能详的指标。无论是产品经理、运营,还是数据分析师,DAU都是衡量产品 ...
2025-03-24ABtest做的好,产品优化效果差不了!可见ABtest在评估优化策略的效果方面地位还是很高的,那么如何在业务中应用ABtest? 结合企业 ...
2025-03-21在企业数据分析中,指标体系是至关重要的工具。不仅帮助企业统一数据标准、提升数据质量,还能为业务决策提供有力支持。本文将围 ...
2025-03-20解锁数据分析师高薪密码,CDA 脱产就业班助你逆袭! 在数字化浪潮中,数据驱动决策已成为企业发展的核心竞争力,数据分析人才的 ...
2025-03-19在 MySQL 数据库中,查询一张表但是不包含某个字段可以通过以下两种方法实现:使用 SELECT 子句以明确指定想要的字段,或者使 ...
2025-03-17在当今数字化时代,数据成为企业发展的关键驱动力,而用户画像作为数据分析的重要成果,改变了企业理解用户、开展业务的方式。无 ...
2025-03-172025年是智能体(AI Agent)的元年,大模型和智能体的发展比较迅猛。感觉年初的deepseek刚火没多久,这几天Manus又成为媒体头条 ...
2025-03-14以下的文章内容来源于柯家媛老师的专栏,如果您想阅读专栏《小白必备的数据思维课》,点击下方链接 https://edu.cda.cn/goods/sh ...
2025-03-13以下的文章内容来源于刘静老师的专栏,如果您想阅读专栏《10大业务分析模型突破业务瓶颈》,点击下方链接 https://edu.cda.cn/go ...
2025-03-12