京公网安备 11010802034615号
经营许可证编号:京B2-20210330
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
在数字化时代,用户是产品的核心资产,用户运营的本质的是通过科学的指标监测、分析与优化,实现“拉新、促活、留存、转化、复购 ...
2026-04-15在企业数字化转型、系统架构设计、数据治理与AI落地过程中,数据模型、本体模型、业务模型是三大核心基础模型,三者相互支撑、各 ...
2026-04-15数据分析师的一天,80%的时间花在表格数据上,但80%的坑也踩在表格数据上。 如果你分不清数值型和文本型的区别,不知道数据从哪 ...
2026-04-15在人工智能与机器学习落地过程中,模型质量直接决定了应用效果的优劣——无论是分类、回归、生成式模型,还是推荐、预测类模型, ...
2026-04-14在Python网络编程、接口测试、爬虫开发等场景中,HTTP请求的发送与响应处理是核心需求。Requests库作为Python生态中最流行的HTTP ...
2026-04-14 很多新人学完Python、SQL,拿到一张Excel表还是不知从何下手。 其实,90%的商业分析问题,都藏在表格的结构里。 ” 引言:为 ...
2026-04-14在回归分析中,因子(即自变量)的筛选是构建高效、可靠回归模型的核心步骤——实际分析场景中,往往存在多个候选因子,其中部分 ...
2026-04-13在机器学习模型开发过程中,过拟合是制约模型泛化能力的核心痛点——模型过度学习训练数据中的噪声与偶然细节,导致在训练集上表 ...
2026-04-13在数据驱动商业升级的今天,商业数据分析已成为企业精细化运营、科学决策的核心手段,而一套规范、高效的商业数据分析总体流程, ...
2026-04-13主讲人简介 张冲,海归统计学硕士,CDA 认证数据分析师,前云南白药集团资深数据分析师,自媒体 Python 讲师,全网课程播放量破 ...
2026-04-13在数据可视化与业务分析中,同比分析是衡量业务发展趋势、识别周期波动的核心手段,其核心逻辑是将当前周期数据与上年同期数据进 ...
2026-04-13在机器学习模型的落地应用中,预测精度并非衡量模型可靠性的唯一标准,不确定性分析同样不可或缺。尤其是在医疗诊断、自动驾驶、 ...
2026-04-10数据本身是沉默的,唯有通过有效的呈现方式,才能让其背后的规律、趋势与价值被看见、被理解、被运用。统计制图(数据可视化)作 ...
2026-04-10在全球化深度发展的今天,跨文化传播已成为连接不同文明、促进多元共生的核心纽带,其研究核心围绕“信息传递、文化解读、意义建 ...
2026-04-09在数据可视化领域,折线图是展示时序数据、趋势变化的核心图表类型之一,其简洁的线条的能够清晰呈现数据的起伏规律。Python ECh ...
2026-04-09在数据驱动的时代,数据分析早已不是“凭经验、靠感觉”的零散操作,而是一套具备固定逻辑、标准化流程的系统方法——这就是数据 ...
2026-04-09长短期记忆网络(LSTM)作为循环神经网络(RNN)的重要改进模型,凭借其独特的门控机制(遗忘门、输入门、输出门),有效解决了 ...
2026-04-08在数据分析全流程中,数据质量是决定分析结论可靠性的核心前提,而异常值作为数据集中的“异类”,往往会干扰统计检验、模型训练 ...
2026-04-08在数字经济飞速发展的今天,数据已渗透到各行各业的核心场景,成为解读趋势、优化决策、创造价值的核心载体。而数据分析,作为挖 ...
2026-04-08在数据分析全流程中,数据处理是基础,图形可视化是核心呈现手段——前者负责将杂乱无章的原始数据转化为干净、规范、可分析的格 ...
2026-04-07