Python绘制可爱的图表 cutecharts
off999 2025-08-02 21:10 3 浏览 0 评论
一个很酷的python手绘样式可视化包——可爱的图表 cutecharts。Cutecharts 非常适合为图表提供更个性化的触感。
Cutecharts 与常规的 Matplotlib 和 Seaborn 库完全不同,它可以查看手工制作的图表,并在将鼠标悬停在图表上时显示值。Matplotlib 图表中没有悬停效果,这是可爱图表的一个优势。与 seaborn 相比,在可爱图表中创建图表的时间要长一些,但代码数量仍然比标准 matplotlib 库少。
该包可用于生成以下类型的图表。目前,该库支持五种不同的图表——条形图、饼图、雷达图、散点图和折线图。
安装cutecharts
这是个python第三方库,要创建此图表,需要安装cutecharts库。具体安装方法与其他库一样。
pip install cutecharts
导入库
import cutecharts.charts as ctc
import pandas as pd
数据集
看看 TMBD 数据是什么样子的?数据有 21 列。
df = pd.read_csv(r'tmdb-movies.csv')
df.head(2)
数据说明
- Popularity流行度: 指定电影流行度的数字量
- Budget预算: 电影制作的预算。
- Revenue收入: 电影产生的全球收入
- Original Title原片名: 翻译或改编前电影的片名。
- Cast演员: 在电影中扮演角色的演员姓名
- Homepage主页: 指向电影主页的链接。
- Director导演: 导演电影的导演姓名。
- Title片名: 电影名称
- Keywords关键字: 与电影相关的关键字或标签。
- Overview概述: 对电影的简要描述
- Runtime运行时间: 以分钟为单位的电影运行时间。
- Genres类型: 电影的类型,剧情、动作、喜剧、惊悚等。
- Production Company制作公司: 电影的制作公司。
- Vote Count投票数: 收到的票数。
- Vote Average投票平均: 电影收到的平均评分。
日期时间
- Release Date上映日期: 电影上映的日期。
- Release Year发行年份: 电影发行的年份。
数据清洗
先清理数据,然后会看到可爱的图表。
将特征更改为正确的日期时间格式并将流行功能四舍五入到小数点后两位,以获得更多内容。
df['release_date'] = pd.to_datetime(df['release_date'])
df['popularity'] = round(df['popularity'], 2)
删除不必要的功能
df.drop(['imdb_id', 'homepage', 'budget_adj','revenue_adj'],
axis=1, inplace=True)
用missing替换特征nan值
df['tagline'].fillna('missing',inplace=True)
df['keywords'].fillna('missing',inplace=True)
df['production_companies'].fillna('missing',inplace=True)
df['cast'].fillna('missing',inplace=True)
df['director'].fillna('missing',inplace=True)
df['genres'].fillna('missing',inplace=True)
df['overview'].fillna('missing',inplace=True)
从预算和收入中删除等于 0 的值。
df.drop(df[(df['budget']==0) & (df['revenue']==0)].index,
inplace=True)
现在,数据是干净的,现在可以进一步创建一些可爱的图表。
cutecharts中使用的参数
分配要的图表名称,例如,要一个饼图然后运行下面的代码。
chart = ctc.Pie()
设置需要width, height在参数中添加的图表的标题、宽度和高度。
chart = ctc.Pie('Title', width='600px', height='300px')
设置图表选项,可以将使用set_options()函数。
chart.set_options()
设置x和y标签的标题,使用x_label, y_label传入set_options()函数示例如下。
chart.set_options(x_label='X Labels',
y_label='Y Labels')
最后,使用一个函数来显示图表render_notebook(),下面给出一个例子。
chart.render_notebook()
绘制饼图
要制作的图表是甜甜圈图表。看到发行量最高的电影的前 5 年。
df_year = df['release_year'].value_counts(
).reset_index().sort_values(by='index',
ascending=False)[:5].rename(columns={'index':'release_year',
'release_year':'Count'})
chart = ctc.Pie('Top 5 years', width='600px', height='300px')
chart.set_options(labels=list(df_year['release_year']), inner_radius=0)
chart.add_series(list(df_year['Count']))
chart.render_notebook()
绘制圆环图
df_year = df['release_year'].value_counts(
).reset_index().sort_values(by='index',
ascending=False)[:5].rename(columns={'index':'release_year',
'release_year':'Count'})
chart = ctc.Pie('Top 5 years', width='600px', height='300px')
chart.set_options(labels=list(df_year['release_year']), inner_radius=0.8)
chart.add_series(list(df_year['Count']))
chart.render_notebook()
条形图代码
from cutecharts.faker import Faker
chart = ctc.Bar('Top Movie Geners', width='600px', height='200px')
chart.set_options(labels=list(df_genre_movies['Drama'][:7]),
x_label='Drama',
y_label='Count',
colors=Faker.colors
)
chart.add_series('Geners',list(df_genre_movies['Count'][:7]))
chart.render_notebook()
绘制雷达图
data = {'Day': ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun'],
'This week': [12, 10, 9, 9, 10, 3, 3],
'Last week': [15, 12, 8, 9, 11, 4, 3]
}
df_coffee = pd.DataFrame(data, columns = ['Day', 'This week', 'Last week'])
相关推荐
- 实战:用 Python+Flask+Echarts 构建电商实时数据大屏
-
在电商运营中,实时掌握销售趋势、用户行为等核心数据是决策的关键。本文将从实战角度,详解如何用Python+Flask+Echarts技术栈,快速搭建一个支持实时更新、多维度可视化的电商数据大屏,帮...
- DeepSeek完全使用手册:从新手到高手的2000字实操指南
-
一、工具定位与核心功能矩阵(200字)DeepSeek是一款专注于深度推理的强大AI助手,其功能丰富多样,可归纳为4大能力象限:plaintext差异化优势:DeepSeek支持最长达16Ktok...
- Python绘制可爱的图表 cutecharts
-
一个很酷的python手绘样式可视化包——可爱的图表cutecharts。Cutecharts非常适合为图表提供更个性化的触感。Cutecharts与常规的Matplotlib和Seabo...
- 第十二章:Python与数据处理和可视化
-
12.1使用pandas进行数据处理12.1.1理论知识pandas是Python中最常用的数据处理库之一,它提供了高效的数据结构和数据分析工具。pandas的核心数据结构是Serie...
- 5分钟就能做一个Excel动态图表,你确定不学学?(纯gif教学)
-
本文说明下图是一个比较酷炫的Excel动态图表,最难的部分就是用到了一个复选框控件。其实这个控件我很早就见过,但是不会用呀!望洋兴叹。这次呢,我也是借着这个文章为大家讲述一下这个控件的使用。本文没有...
- Python数据可视化:从Pandas基础到Seaborn高级应用
-
数据可视化是数据分析中不可或缺的一环,它能帮助我们直观理解数据模式和趋势。本文将全面介绍Python中最常用的三种可视化方法。Pandas内置绘图功能Pandas基于Matplotlib提供了简洁的绘...
- 如何使用 Python 将图表写入 Excel
-
将Python生成的图表写入Excel文件是数据分析和可视化中常见的需求。Python提供了多种库(如matplotlib、openpyxl和xlsxwriter)来实现这一功能。本文...
- Excel 图表制作太痛苦?用 Python 生成动态交互图表
-
做个动态图表花了3小时?你该换方法了!上周帮销售部做季度汇报图表,Excel操作把我整崩溃了——插入折线图后发现数据源选错,重新选择又得调格式想做动态筛选图表,捣鼓"开发工具"...
- Python Matplotlib 入门教程:可视化数据的基石
-
一、简介Matplotlib是Python中最流行的数据可视化库,提供从简单折线图到复杂3D图形的完整解决方案。其核心优势在于:o灵活性强:支持像素级样式控制o兼容性好:与NumPy、Pa...
- 20种Python数据可视化绘图 直接复制可用
-
本文介绍20种python数据绘图方法,可直接用于科研绘图或汇报用图。1.折线图(LinePlot)-描述数据随时间或其他变量的变化。importmatplotlib.pyplotasp...
- Python os模块完全指南:轻松玩转文件管理与系统操作
-
Pythonos模块完全指南:轻松玩转文件管理与系统操作os模块是Python与操作系统对话的"瑞士军刀",学会它能让你轻松管理文件、操控路径、获取系统信息。本教程通过场景化案例+...
- Python中h5py与netCDF4模块在Anaconda环境的下载与安装
-
本文介绍基于Anaconda环境,下载并安装Python中h5py与netCDF4这两个模块的方法。h5py与netCDF4这两个模块是与遥感图像处理、地学分析等GIS操作息息相关的模块,应用...
- python中的模块、库、包有什么区别?
-
一文带你分清Python模块、包和库。一、模块Python模块(Module),是一个Python文件,以.py结尾,包含了Python对象定义和Python语句。模块能定义函数,类和变...
- centos7 下面使用源码编译的方式安装python3.11
-
centos7下面使用源码编译的方式安装python3.11,步骤如下:cd/root#只是将python3.11的安装包下载到/root目录下wgethttps://www.python.o...
- Python其实很简单 第十四章 模块
-
模块是一组程序代码,可以是别人已经写好的,也可以是自己编写的,但都是已经存在的,在编程时直接使用就可以了。模块机制的最大好处就是程序员不再编写重复的代码,而直接利用已有的成果,这样就能将更多的精力投入...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- python计时 (73)
- python安装路径 (56)
- python类型转换 (93)
- python进度条 (67)
- python吧 (67)
- python的for循环 (65)
- python格式化字符串 (61)
- python静态方法 (57)
- python列表切片 (59)
- python面向对象编程 (60)
- python 代码加密 (65)
- python串口编程 (77)
- python封装 (57)
- python读取文件夹下所有文件 (59)
- java调用python脚本 (56)
- python操作mysql数据库 (66)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python多态 (60)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)