首页 > 其他分享 >从基础到进阶:用 Plotly 实现交互式数据可视化

从基础到进阶:用 Plotly 实现交互式数据可视化

时间:2024-09-12 11:23:06浏览次数:16  
标签:layout 进阶 title Sales 图表 dict Plotly go 可视化

在数据科学和数据分析领域,数据可视化是一种非常重要的技术。Plotly 是一个功能强大的 Python 可视化库,它可以帮助我们创建交互式的数据可视化图表。本文将介绍如何使用 Plotly 实现交互式数据可视化,包括数据准备、图表创建和交互功能的添加。

步骤

1. 安装 Plotly

首先,确保已经安装了 Plotly。如果没有安装,可以使用 pip 进行安装:

pip install plotly

2. 准备数据

在进行数据可视化之前,需要准备好要可视化的数据。在本示例中,我们将使用一个简单的数据集。

import pandas as pd

# 创建示例数据
data = {
    'Year': [2015, 2016, 2017, 2018, 2019],
    'Sales': [100, 150, 200, 250, 300]
}

df = pd.DataFrame(data)

3. 创建交互式图表

使用 Plotly 来创建交互式图表非常简单。下面是一个简单的例子,创建一个折线图:

import plotly.graph_objs as go

# 创建折线图
trace = go.Scatter(x=df['Year'], y=df['Sales'], mode='lines', name='Sales')

# 创建布局
layout = go.Layout(title='Yearly Sales', xaxis=dict(title='Year'), yaxis=dict(title='Sales'))

# 创建图表对象
fig = go.Figure(data=[trace], layout=layout)

# 显示图表
fig.show()

4. 添加交互功能

Plotly 提供了丰富的交互功能,可以让用户与图表进行互动。例如,我们可以添加鼠标悬停提示信息:

# 添加鼠标悬停提示信息
trace = go.Scatter(x=df['Year'], y=df['Sales'], mode='lines', name='Sales',
                   hoverinfo='x+y', line=dict(color='blue'))

# 创建布局
layout = go.Layout(title='Yearly Sales', xaxis=dict(title='Year'), yaxis=dict(title='Sales'))

# 创建图表对象
fig = go.Figure(data=[trace], layout=layout)

# 显示图表
fig.show()

5. 更多交互功能

除了鼠标悬停提示信息之外,Plotly 还支持许多其他交互功能,如缩放、平移、选择和标记等。你可以根据需要添加这些功能来提升用户体验。

import pandas as pd
import plotly.graph_objs as go

# 创建示例数据
data = {
    'Year': [2015, 2016, 2017, 2018, 2019],
    'Sales': [100, 150, 200, 250, 300]
}

df = pd.DataFrame(data)

# 创建折线图
trace = go.Scatter(x=df['Year'], y=df['Sales'], mode='lines', name='Sales',
                   hoverinfo='x+y', line=dict(color='blue'))

# 创建布局
layout = go.Layout(title='Yearly Sales', xaxis=dict(title='Year'), yaxis=dict(title='Sales'))

# 创建图表对象
fig = go.Figure(data=[trace], layout=layout)

# 显示图表
fig.show()

6. 导出图表

一旦你创建了交互式的图表,你可能想要将它导出到文件中以供分享或嵌入到网页中。Plotly 提供了多种导出图表的方法,包括静态图片和交互式 HTML 文件。

导出静态图片

# 导出为静态图片
fig.write_image("sales_plot.png")

导出为 HTML 文件

# 导出为 HTML 文件
fig.write_html("sales_plot.html")

这样,你就可以轻松地将交互式图表分享给其他人或者嵌入到网页中。

import pandas as pd
import plotly.graph_objs as go

# 创建示例数据
data = {
    'Year': [2015, 2016, 2017, 2018, 2019],
    'Sales': [100, 150, 200, 250, 300]
}

df = pd.DataFrame(data)

# 创建折线图
trace = go.Scatter(x=df['Year'], y=df['Sales'], mode='lines', name='Sales',
                   hoverinfo='x+y', line=dict(color='blue'))

# 创建布局
layout = go.Layout(title='Yearly Sales', xaxis=dict(title='Year'), yaxis=dict(title='Sales'))

# 创建图表对象
fig = go.Figure(data=[trace], layout=layout)

# 添加交互功能
fig.update_layout(
    xaxis=dict(
        rangeselector=dict(
            buttons=list([
                dict(count=1, label="1年", step="year", stepmode="backward"),
                dict(count=2, label="2年", step="year", stepmode="backward"),
                dict(count=3, label="3年", step="year", stepmode="backward"),
                dict(count=4, label="4年", step="year", stepmode="backward"),
                dict(step="all")
            ])
        ),
        rangeslider=dict(visible=True),
        type="date"
    )
)

# 导出为静态图片
fig.write_image("sales_plot.png")

# 导出为 HTML 文件
fig.write_html("sales_plot.html")

# 显示图表
fig.show()

通过以上步骤,你可以轻松地创建、定制并分享交互式的数据可视化图表,为数据分析工作增添更多的乐趣和效率!

7. 自定义图表样式

Plotly 允许你对图表样式进行高度定制,以满足特定需求或者提升可视化效果。

修改线条样式

# 修改线条样式
trace = go.Scatter(x=df['Year'], y=df['Sales'], mode='lines+markers', name='Sales',
                   hoverinfo='x+y', line=dict(color='blue', width=2), marker=dict(size=8, color='red'))

调整布局

# 调整布局
layout = go.Layout(title='Yearly Sales', xaxis=dict(title='Year', showgrid=False), yaxis=dict(title='Sales', showgrid=False))

添加标题和标签

# 添加标题和标签
fig.update_layout(title_text="Yearly Sales", xaxis_title="Year", yaxis_title="Sales")

通过以上调整,你可以根据需要自定义图表的外观和布局。

import pandas as pd
import plotly.graph_objs as go

# 创建示例数据
data = {
    'Year': [2015, 2016, 2017, 2018, 2019],
    'Sales': [100, 150, 200, 250, 300]
}

df = pd.DataFrame(data)

# 创建折线图
trace = go.Scatter(x=df['Year'], y=df['Sales'], mode='lines+markers', name='Sales',
                   hoverinfo='x+y', line=dict(color='blue', width=2), marker=dict(size=8, color='red'))

# 创建布局
layout = go.Layout(title='Yearly Sales', xaxis=dict(title='Year', showgrid=False), yaxis=dict(title='Sales', showgrid=False))

# 创建图表对象
fig = go.Figure(data=[trace], layout=layout)

# 添加交互功能
fig.update_layout(
    xaxis=dict(
        rangeselector=dict(
            buttons=list([
                dict(count=1, label="1年", step="year", stepmode="backward"),
                dict(count=2, label="2年", step="year", stepmode="backward"),
                dict(count=3, label="3年", step="year", stepmode="backward"),
                dict(count=4, label="4年", step="year", stepmode="backward"),
                dict(step="all")
            ])
        ),
        rangeslider=dict(visible=True),
        type="date"
    )
)

# 添加标题和标签
fig.update_layout(title_text="Yearly Sales", xaxis_title="Year", yaxis_title="Sales")

# 导出为静态图片
fig.write_image("sales_plot.png")

# 导出为 HTML 文件
fig.write_html("sales_plot.html")

# 显示图表
fig.show()

通过以上步骤,你可以更加灵活地定制和分享交互式的数据可视化图表!

总结

在这篇文章中,我们学习了如何使用 Plotly 实现交互式数据可视化的步骤。以下是我们探讨的主要内容:

  1. 安装 Plotly:首先,我们确保安装了 Plotly 库,它是一个功能强大的 Python 可视化库。
  2. 准备数据:在进行数据可视化之前,我们需要准备好要可视化的数据。我们使用了一个简单的示例数据集作为演示。
  3. 创建交互式图表:我们使用 Plotly 创建了一个交互式折线图,并学习了如何调整布局和添加交互功能,例如鼠标悬停提示信息和范围选择器。
  4. 导出图表:我们还学习了如何将交互式图表导出为静态图片或 HTML 文件,以便分享或嵌入到网页中。
  5. 自定义图表样式:最后,我们探讨了如何自定义图表样式,包括修改线条样式、调整布局以及添加标题和标签,以满足特定需求或提升可视化效果。

通过以上步骤,你可以轻松地创建、定制并分享交互式的数据可视化图表,为数据分析工作增添更多的乐趣和效率!

从基础到进阶:用 Plotly 实现交互式数据可视化_Sales

标签:layout,进阶,title,Sales,图表,dict,Plotly,go,可视化
From: https://blog.51cto.com/u_16123336/11990305

相关文章

  • Docker 可视化工具
    1.PortainerPortainer是一个可视化的容器镜像的图形管理工具,利用Portainer可以轻松构建,管理和维护Docker环境。而且完全免费,基于容器化的安装方式,方便高效部署。官方站点:https://www.portainer.io/ 2.DockerUI DockerUI是一款开源的、强大的、轻量级的Docker管理工具......
  • 利用AI驱动智能BI数据可视化-深度评测Amazon Quicksight(三)
    简介随着生成式人工智能的兴起,传统的BI报表功能已经无法满足用户对于自动化和智能化的需求,今天我们将介绍亚马逊云科技平台上的AI驱动数据可视化神器–Quicksight,利用生成式AI的能力来加速业务决策,从而提高业务生产力。借助Quicksight中集成的AmazonQ的创作功能,业务分析......
  • 基于SSM+uniapp的电子书籍阅读小程序可视化分析系统的设计与实现 ljh4j
    目录技术介绍具体实现截图微信开发者工具HBuilderXuniapp系统设计java类核心代码部分展示登录的业务流程的顺序是:可行性论证详细视频演示技术可行性系统测试系统安全性数据完整性实现思路系统实现源码获取技术介绍如今微信小程序有以下发展优势(1)无须下载,无须注......
  • uniapp微信小程序的老年防诈科普及交流平台设计和实现 f254d可视化分析系统
    目录技术介绍具体实现截图微信开发者工具HBuilderXuniapp系统设计java类核心代码部分展示登录的业务流程的顺序是:可行性论证详细视频演示技术可行性系统测试系统安全性数据完整性实现思路系统实现源码获取技术介绍如今微信小程序有以下发展优势(1)无须下载,无须注......
  • Linux进阶命令-echo&date&alias
    作者介绍:简历上没有一个精通的运维工程师。希望大家多多关注作者,下面的思维导图也是预计更新的内容和当前进度(不定时更新)。经过上一章Linux日志的讲解,我们对Linux系统自带的日志服务已经有了一些了解。我们接下来将讲解一些进阶命令,主要从以下几个方面来讲解:一些系统操作,系......
  • 基于数据可视化大屏+SpringBoot的校园篮球信息与购物平台设计和实现(源码+论文+部署讲
    博主介绍:✌全网粉丝50W+,csdn特邀作者、博客专家、CSDN新星计划导师、Java领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和学生毕业项目实战,高校老师/讲师/同行前辈交流✌技术范围:SpringBoot、Vue、SSM、HLMT、Jsp、PHP、Nodejs、P......
  • 解锁10款超棒的图表制作软件,让数据可视化不再困难
    你还在使用excel和PPT制作图表,却苦恼做出来的图表不够漂亮和灵活好用吗?你还在每到工作汇报/论文发表,都要临时抱佛脚去找图表制作软件吗?今天给大家整理了10个免费、简单好用的在线图表制作软件~速度收藏起来,工作汇报不用愁。1、积木报表介绍:积木报表是一款免费的数据可视化报......
  • 五星级可视化页面(04):城市鸟瞰地图,恢宏大气。
    今天继续分享五星级可视化大屏界面,本期分享城市3D鸟瞰图的,非常的恢宏大气。  ......
  • 五星级可视化页面(15):各类医疗场景下大屏页面
    可视化大屏在医疗领域有许多重要的价值和应用:1.数据监控和实时展示:可视化大屏可以用于监控医疗设备、患者数据、手术过程等,实时展示医疗数据的变化和趋势,帮助医护人员及时发现异常情况并做出相应的处理。2.医院运营管理:可视化大屏可以展示医院的运营数据,包括门诊量、......
  • 《JavaEE进阶》----14.<SpringMVC配置文件实践之【验证码项目】>
    本篇博客介绍的是Google的开源项目Kaptcha来实现的验证码。这种是最简单的验证码。也是很常见的一种验证码。可以去看项目结果展示。就可以明白这个项目了。前言:随着安全性的要求越来越高、很多项目都使用了验证码。如今验证码的形式也是有许许多多、更复杂的图形验证码......