Pandas pyecharts数据可视化基础③

news2025/5/19 23:41:56

引言

本文将详细介绍使用pyecharts库进行基础绘图的相关代码案例,包括三维散点图、漏斗图和词云图的绘制。pyecharts是一个用于生成 ECharts 图表的 Python 库,ECharts 是一个由百度开源的数据可视化工具,凭借其丰富的图表类型和强大的交互性,被广泛应用于数据可视化领域。

思维导图

graph LR
    classDef process fill:#E5F6FF,stroke:#73A6FF,stroke-width:2px;
    
    A(基础绘图案例):::process --> B(三维散点图):::process
    A --> C(漏斗图):::process
    A --> D(词云图):::process
    B --> B1(最大携氧能力、体重和运动后心率):::process
    C --> C1(某淘宝店铺的订单转化率):::process
    D --> D1(部分宋词词频):::process

代码案例分析

提前安装依赖

在这里插入图片描述

打开Anaconda Prompt
输入pip install pyecharts
在这里插入图片描述

同样操作

在 Anaconda Prompt 中安装这四个包的完整代码如下:

  1. 安装 webdriver - manager
pip install webdriver - manager
  1. 安装 ipykernel
pip install ipykernel
  1. 安装 selenium
pip install selenium
  1. 安装 pyecharts - snapshot
pip install pyecharts - snapshot

安装完重新启动Jupyter Notebook

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述在这里插入图片描述

三维散点图(代码5 - 40)

在这里插入图片描述
在这里插入图片描述

# 代码5-40
import pandas as pd
import numpy as np
from pyecharts import options as opts
from pyecharts.charts import Scatter3D

# 读取数据

player_data = pd.read_excel('./运动员的最大携氧能力、体重和运动后心率数据.xlsm',
 sheet_name=2)
print("DataFrame列名:", player_data.columns)
# 确保列名与 Excel 中的一致(英文括号)
player_data = [
    player_data['体重(kg)'],         # 英文括号
    player_data['运动后心率(次/分钟)'],  # 英文括号
    player_data['最大携氧能力(ml/min)']   # 英文括号
]
player_data = np.array(player_data).T.tolist()

s = (Scatter3D()
   .add('', player_data, 
        xaxis3d_opts=opts.Axis3DOpts(name='体重(kg)'),  # 英文括号
        yaxis3d_opts=opts.Axis3DOpts(name='运动后心率(次/分钟)'),  # 英文括号
        zaxis3d_opts=opts.Axis3DOpts(name='最大携氧能力(ml/min)')
       )
   .set_global_opts(title_opts=opts.TitleOpts(
        title='最大携氧能力、体重和运动后心率3D散点图'), 
                     visualmap_opts=opts.VisualMapOpts(range_color=[
                         '#1710c0', '#0b9df0', '#00fea8', '#00ff0d', 
                         '#f5f811', '#f09a09', 
                         '#fe0300'])))
s.render_notebook()

代码结果

在这里插入图片描述

代码解析
  1. 导入库:导入pandasnumpy用于数据处理,从pyecharts中导入optionsScatter3D用于绘图。
  2. 数据处理:使用pandasread_excel方法读取 Excel 文件,提取所需列的数据,将其转换为numpy数组,再转置并转换为列表。
  3. 创建图表:使用Scatter3D创建三维散点图对象,调用add方法添加数据,并设置三个坐标轴的名称。
  4. 设置全局选项:使用set_global_opts方法设置图表标题和视觉映射选项,包括颜色范围。
  5. 渲染图表:调用render_notebook方法在 Jupyter Notebook 中渲染图表。

漏斗图(代码5 - 41)

在这里插入图片描述
在这里插入图片描述

# 代码5-41
import pandas as pd
import numpy as np
from pyecharts import options as opts
from pyecharts.charts import Funnel
data = pd.read_excel('./某淘宝店铺的订单转化率统计数据.xlsm', sheet_name=1)
print("DataFrame列名:", data.columns)
x_data = data['网购环节'].tolist()
y_data = data['人数'].tolist()
data = [[x_data[i], y_data[i]] for i in range(len(x_data))]
funnel = (Funnel()
    .add('', data_pair=data,label_opts=opts. LabelOpts(
        position='inside', formatter='{b}:{d}%'), gap=2, 
        tooltip_opts=opts.TooltipOpts(trigger='item'), 
        itemstyle_opts=opts.ItemStyleOpts(border_color='#fff', border_width=1))
    .set_global_opts(title_opts=opts.TitleOpts(title='某淘宝店铺的订单转化率漏斗图'), 
                     legend_opts=opts.LegendOpts(pos_left='40%')))
funnel.render_notebook()

结果

在这里插入图片描述

代码解析
  1. 导入库:从pyecharts.charts中导入Funnel用于绘制漏斗图。
  2. 数据处理:使用pandasread_excel方法读取 Excel 文件,将网购环节人数列的数据转换为列表,并组合成二维列表。
  3. 创建图表:使用Funnel创建漏斗图对象,调用add方法添加数据,设置标签位置、格式,间隔、提示框和项目样式。
  4. 设置全局选项:使用set_global_opts方法设置图表标题和图例位置。
  5. 渲染图表:调用render_notebook方法在 Jupyter Notebook 中渲染图表。

词云图(代码5 - 42)

在这里插入图片描述
在这里插入图片描述

# 代码5-42
from pyecharts.charts import WordCloud
data_read = pd.read_csv('./worldcloud.csv', encoding='gbk')
words = list(data_read['词语'].values)
num = list(data_read['频数'].values)
data = [k for k in zip(words, num)]
data = [(i,str(j)) for i, j in data]
wordcloud = (WordCloud()
           .add('', data_pair=data, word_size_range=[10, 100])
           .set_global_opts(title_opts=opts.TitleOpts(
               title='部分宋词词频词云图', title_textstyle_opts=
               opts.TextStyleOpts(font_size=23)), 
                            tooltip_opts=opts.TooltipOpts(is_show=True))
      )
wordcloud.render_notebook()

结果

在这里插入图片描述

代码解析
  1. 导入库:从pyecharts.charts中导入WordCloud用于绘制词云图。
  2. 数据处理:使用pandasread_csv方法读取 CSV 文件,将词语频数列的数据转换为列表,并组合成元组列表,将频数转换为字符串类型。
  3. 创建图表:使用WordCloud创建词云图对象,调用add方法添加数据,设置词云图的大小范围。
  4. 设置全局选项:使用set_global_opts方法设置图表标题和提示框选项。
  5. 渲染图表:调用render_notebook方法在 Jupyter Notebook 中渲染图表。

总结

通过本文的学习,你可以掌握以下知识与技能:

  1. 学会使用pyecharts库绘制三维散点图、漏斗图和词云图。
  2. 掌握使用pandas进行数据读取和处理的基本方法。
  3. 了解pyecharts中图表对象的创建、数据添加和全局选项设置的方法。
  4. 学会在 Jupyter Notebook 中渲染pyecharts图表。

这些技能将帮助你在数据可视化领域更好地展示和分析数据,为数据分析和决策提供有力支持。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2379600.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

数据库中关于查询选课问题的解法

前言 今天上午起来复习了老师上课讲的选课问题。我总结了三个解法以及一点注意事项。 选课问题介绍 简单来说就是查询某某同学没有选或者选了什么课。然后查询出该同学的姓名,学号,课程号,课程名之类的。 sql文件我上传了。大家可以尝试练…

基于Bootstrap 的网页html css 登录页制作成品

目录 前言 一、网页制作概述 二、登录页面 2.1 HTML内容 2.2 CSS样式 三、技术说明书 四、页面效果图 前言 ‌Bootstrap‌是一个用于快速开发Web应用程序和网站的前端框架,由Twitter的设计师Mark Otto和Jacob Thornton合作开发。 它基于HTML、CSS和JavaScri…

组件导航 (Navigation)+flutter项目搭建-混合开发+分栏

组件导航 (Navigation)flutter项目搭建 接上一章flutter项目的环境变量配置并运行flutter 上一章面熟了搭建flutter并用编辑器运行了ohos项目,这章主要是对项目的工程化改造 先创建flutter项目,再配置Navigation 1.在开发视图的resources/base/profi…

ProfibusDP主站转modbusTCP网关与ABB电机保护器数据交互

ProfibusDP主站转modbusTCP网关与ABB电机保护器数据交互 在工业自动化领域,Profibus DP(Process Field Bus)和Modbus TCP是两种常见的通讯协议,它们各自在不同的场合发挥着重要作用。然而,随着技术的发展和应用需求的…

ubuntu24.04上安装NVIDIA driver+CUDA+cuDNN+Anaconda+Pytorch

一、NVIDIA driver 使用Ubuntu系统的:软件和更新——>附加驱动,安装NVIDIA驱动。 二、CUDA 安装命令:sudo apt install nvidia-cuda-toolkit 三、cuDNN cuDNN 9.10.0 Downloads | NVIDIA Developer 四、Anaconda Download Anaconda Di…

3、函数和约束

# 提供的数据sql CREATE TABLE IF NOT EXISTS student(no BIGINT(20) NOT NULL AUTO_INCREMENT PRIMARY KEY COMMENT 学号,name VARCHAR(20) NOT NULL COMMENT 姓名,sex VARCHAR(2) DEFAULT 男 COMMENT 性别, age INT(3) DEFAULT 0 COMMENT 年龄,score DOUBLE(5,2) COMMENT 成绩…

PhpStudy | PhpStudy 工具安装 —— Windows 系统安装 PhpStudy

🌟想了解这个工具的其它相关笔记?看看这个:[网安工具] 服务器环境配置工具 —— PhpStudy 使用手册 笔者备注:Windows 中安装 PhpStudy 属于傻瓜式安装,本文只是为了体系完善而发。 在前面的章节中,笔者简…

基于vue框架的订单管理系统r3771(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。

系统程序文件列表 项目功能:商家,用户,商品信息,订单信息,订单配送,评价记录 开题报告内容 基于Vue框架的订单管理系统开题报告 一、研究背景与意义 随着电子商务的快速发展和消费者购物习惯的改变,传统订单管理方式面临效率低、易出错、难以适应高并…

语音识别——语音转文字

SenseVoiceSmall阿里开源大模型,SenseVoice 是具有音频理解能力的音频基础模型,包括语音识别(ASR)、语种识别(LID)、语音情感识别(SER)和声学事件分类(AEC)或…

兰亭妙微:用系统化思维重构智能座舱 UI 体验

兰亭妙微设计专注于以产品逻辑驱动的界面体验优化,服务领域覆盖AI交互、智能穿戴、IoT设备、智慧出行等多个技术密集型产业。我们倡导以“系统性设计”为方法论,在用户需求与技术边界之间找到最优解。 此次智能驾驶项目,我们为某车载平台提供…

计算机视觉----基础概念、卷积

一、概述 1.计算机视觉的定义 计算机视觉(Computer Vision)是一个跨学科的研究领域,主要涉及如何使计算机能够通过处理和理解数字图像或视频来自动进行有意义的分析和决策。其目标是使计算机能够从视觉数据中获取高层次的理解,类似于人类的视觉处理能力。 具体来说,计算机…

第三十七节:视频处理-视频读取与处理

引言:解码视觉世界的动态密码 在数字化浪潮席卷全球的今天,视频已成为信息传递的主要载体。从短视频平台的爆火到自动驾驶的视觉感知,视频处理技术正在重塑人类与数字世界的交互方式。本指南将深入探讨视频处理的核心技术,通过Python与OpenCV的实战演示,为您揭开动态影像…

NSSCTF [GFCTF 2021]where_is_shell

889.[GFCTF 2021]where_is_shell(system($0)64位) [GFCTF 2021]where_is_shell (1) 1.准备 motalymotaly-VMware-Virtual-Platform:~$ file shell shell: ELF 64-bit LSB executable, x86-64, version 1 (SYSV), dynamically linked, interpreter /lib64/ld-linux-x86-64.s…

电子数据取证(数字取证)技术全面指南:从基础到实践

为了后续查阅方便,推荐工具先放到前面 推荐工具 数字取证基础工具 综合取证平台 工具名称类型主要功能适用场景EnCase Forensic商业全面的证据获取和分析、强大的搜索能力法律诉讼、企业调查FTK (Forensic Toolkit)商业高性能处理和索引、集成内存分析大规模数据处…

Ubuntu使用Docker搭建SonarQube企业版(含破解方法)

目录 Ubuntu使用Docker搭建SonarQube企业版(含破解方法)SonarQube介绍安装Docker安装PostgreSQL容器Docker安装SonarQube容器SonarQube汉化插件安装 破解生成license配置agent 使用 Ubuntu使用Docker搭建SonarQube企业版(含破解方法&#xff…

Django 项目的 models 目录中,__init__.py 文件的作用

在 Django 项目的models/init.py文件中,这些导入语句的主要作用是将各个模型类从不同的模块中导入到models包的命名空间中。这样做有以下几个目的: 简化导入路径 当你需要在项目的其他地方使用这些模型时,可以直接从models包导入&#xff0c…

网络的知识的一些概念

1.什么是局域网,什么是广域网 局域网(Local area network)也可以称为本地网,内网,局域网有这几个发展经历: 最开始电脑与电之间是直接用网线连接的 再后来有了集线器() 再后来出…

芋道项目,商城模块数据表结构

一、需求 最近公司有新的业务需求,调研了一下,决定使用芋道(yudao-cloud)框架,于是从github(https://github.com/YunaiV/yudao-cloud)上克隆项目,选用的是jdk17版本的。根据项目启动手册&#…

【氮化镓】HfO2钝化优化GaN 器件性能

2025年,南洋理工大学的Pradip Dalapati等人在《Applied Surface Science》期刊发表了题为《Role of ex-situ HfO2 passivation to improve device performance and suppress X-ray-induced degradation characteristics of in-situ Si3N4/AlN/GaN MIS-HEMTs》的文章。该研究基…

SQLMesh 增量模型从入门到精通:5步实现高效数据处理

本文深入解析 SQLMesh 中的增量时间范围模型,介绍其核心原理、配置方法及高级特性。通过实际案例说明如何利用该模型提升数据加载效率,降低计算资源消耗,并提供配置示例与最佳实践建议,帮助读者在实际项目中有效应用这一强大功能。…