用 Python 绘制企业年度财务可视化报告 —— 从 Excel 到 9 种图表全覆盖

用 Python 绘制企业年度财务可视化报告 —— 从 Excel 到 9 种图表全覆盖

在企业经营分析中,光看一堆财务数字很难直观发现规律和问题。 如果能将这些数据转化为可视化图表,不仅更美观,还能帮助管理层快速做出决策。

今天,我就用 Python + Pandas + Matplotlib,从一份 Excel 财务数据出发,生成一个包含 9 种图表 的年度财务可视化报告。


1. 数据准备

已经有一份 企业财务数据.xlsx,里面的 “财务数据” 工作表包含如下列:

  • 月份

  • 收入

  • 总成本

  • 利润

  • 销售数量

  • 可变成本

  • 固定成本

  • 利润率(%)

图片

用 Pandas 读取文件并做基础检查:

import pandas as pdfile_path = '企业财务数据.xlsx'
df = pd.read_excel(file_path, sheet_name='财务数据')required_cols = ['月份', '收入', '总成本', '利润', '销售数量', '可变成本', '固定成本', '利润率(%)']
if not all(col in df.columns for col in required_cols):print("Excel 缺少必要列!")exit()

2. 图表总览

我一次性生成 3x3 布局的 9 个子图,涵盖柱形图、折线图、雷达图、气泡图等多种形式。

图片

下面按顺序介绍每张图的用途和实现方法。


① 柱形图:每月利润

直观展示全年每个月的利润变化趋势。

图片

ax1.bar(df['月份'], df['利润'], color='skyblue', alpha=0.8)

② 对比柱形图:收入 vs 总成本

用并列柱形对比每个月的收入和总成本,方便查看盈亏情况。

图片

ax2.bar(x, df['收入'], width, label='收入')
ax2.bar(x + width, df['总成本'], width, label='总成本')

③ 分组柱形图:收入、可变成本、固定成本

进一步拆分成本构成,比较三项数据。

图片

ax3.bar(x - width, df['收入'], width, label='收入')
ax3.bar(x, df['可变成本'], width, label='可变成本')
ax3.bar(x + width, df['固定成本'], width, label='固定成本')

④ 堆积柱形图:总成本构成

用堆积方式将可变成本和固定成本叠加,直观看到成本比例。

图片

ax4.bar(df['月份'], df['可变成本'])
ax4.bar(df['月份'], df['固定成本'], bottom=df['可变成本'])

⑤ 分区折线图:利润与利润率

双 Y 轴折线图,一边显示利润走势,一边显示利润率。

图片

ax5.plot(df['月份'], df['利润'], marker='o')
ax6.plot(df['月份'], df['利润率(%)'], linestyle='--')

⑥ 雷达图:四个季度关键指标对比

将收入、总成本、利润、销量这四个指标按季度进行归一化对比。

图片

from sklearn.preprocessing import MinMaxScaler
scaler = MinMaxScaler()
q_normalized = scaler.fit_transform(q_data)

⑦ 聚合气泡图:销量 vs 收入

气泡大小代表利润,颜色代表利润率,多维度综合展示业务情况。

图片

scatter = ax8.scatter(df['销售数量'], df['收入'],s=df['利润']/100,c=df['利润率(%)'], cmap='coolwarm')

⑧ 玫瑰图(南丁格尔图):各月利润分布

用极坐标形式绘制每个月利润的分布情况,视觉效果独特。

图片

ax9 = fig.add_subplot(3, 3, 8, projection='polar')
ax9.bar(angles, df['利润'], width=0.5)

⑨ 文本框总结

直接在图中用文本列出年度关键财务指标总结。

图片

summary_text = f"""
📊 年度财务总结
总收入: {df['收入'].sum():,} 元
总成本: {df['总成本'].sum():,} 元
总利润: {df['利润'].sum():,} 元
平均利润率: {df['利润率(%)'].mean():.2f}%
"""
ax10.text(0.5, 0.5, summary_text, ha='center', va='center')

3. 最终效果

运行脚本后,你将得到一张包含 9 种可视化图表 的财务报告:

  • 从整体到细节

  • 从单一维度到多维对比

  • 既有数据可读性,又有展示美感

这份图表不仅能用于内部财务分析,还可以直接嵌入到年终报告 PPT 里,省时省力。


4. 知识点总结

通过这次实战,你可以学到:

  • Pandas 用于读取和处理 Excel 数据

  • Matplotlib 绘制多种类型图表

  • MinMaxScaler 对不同指标进行归一化

  • 如何组合多图,生成一份完整的可视化分析报告

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

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

相关文章

一次 Unity ↔ Android 基于 RSA‑OAEP 的互通踩坑记

这篇分享,记录我如何从“Base64 报错/平台不支持/解密失败”一路定位到“填充算法不一致”的根因,并给出两条稳定落地方案。同时整理了调试手册、代码片段和上线前自检清单,方便你复用。 背景 Unity 端用公钥加密一段紧凑 JSON(i…

Go语言GC机制:高效并发回收解析

Go 语言的垃圾回收(Garbage Collection,简称 GC)是其自动内存管理的核心机制,旨在自动识别并回收不再被使用的内存,避免内存泄漏,减轻开发者的手动内存管理负担。Go 的 GC 算法经历了多次迭代优化&#xff…

imx6ull-驱动开发篇23——Linux 内核定时器实验

目录 实验程序编写 修改设备树文件 定时器驱动程序 timer.c 测试 timerApp.c Makefile 文件 运行测试 实验程序编写 本讲实验,我们使用正点原子I.MX6U-ALPHA 开发板,通过linux内核定时器周期性的点亮和熄灭开发板上的 LED 灯, LED 灯…

IPTV系统:开启视听与管理的全新篇章

在当今数字化飞速发展的时代,IPTV系统正以前所未有的姿态,重塑着我们的视听体验与管理模式。它不仅仅是一套技术系统,更是连接信息、沟通情感、提升效率的桥梁,为各个领域带来了全新的变革与发展机遇。从电视直播的角度来看&#…

PyTorch笔记9----------Cifar10图像分类

1.图像分类网络模型框架解读 分类网络的基本结构 数据加载模块:对训练数据加载数据重组:组合成网络需要的形式,例如预处理、增强、各种网络处理、loss函数计算优化器 数据加载模块 使用公开数据集:torchvision.datasets使用自定义…

飞凌OK3568开发板QT应用程序编译流程

飞凌OK3568开发板QT应用程序编译流程开发环境:ubuntu20.04(主机)、飞凌OK3568开发板一般在linux系统下开发用于ARM开发板的QT应用程序时,直接在主机上开发然后进行交叉编译即可,但有时候ARM开发板的厂家提供的SDK中可能…

飞算JavaAI合并项目实战:7天完成3年遗留系统重构

引言 企业数字化进程中,遗留系统改造始终是CIO面临的头号难题。某电商平台的实践数据显示:3年以上的Java项目平均存在47%的冗余代码,63%的架构设计不符合当前业务需求,进行系统性重构需要投入相当于原开发量200%的资源。传统&quo…

卫星速度增量和比冲及推力之间的关系

一、定义1.1.比冲(Isp):比冲是衡量发动机性能的重要指标,反映了单位重量推进剂在发动机中产生的冲量,单位为米/秒(m/s),代表燃料燃烧时喷流速度。这个单位与速度单位“米/秒”相同&a…

MATLAB绘制各种心形曲线

1.方程(1)心形线的经典隐函数方程为:(2)参数方程(更平滑的心形):(3)极坐标心形线(4)参数方程(3D心形)(5)隐函数3D心形2. MATLAB代码clc;close all;clear all;warning off;%清除变量 rand(seed, 100); randn…

Django REST Framework视图

Django REST Framework (DRF) 视图类详解DRF 提供了丰富的视图类来构建 API,从基础到高级,满足不同复杂度的需求。以下是 DRF 的主要视图类及其使用场景:1. 基础视图类APIView所有 DRF 视图的基类,相当于 Django 的 View 类的增强…

Linux面试题及详细答案 120道(1-15)-- 基础概念

《前后端面试题》专栏集合了前后端各个知识模块的面试题,包括html,javascript,css,vue,react,java,Openlayers,leaflet,cesium,mapboxGL,threejs&…

week1-[分支结构]中位数

week1-[分支结构]中位数 题目描述 给定 444 个正整数 a,b,c,da,b,c,da,b,c,d,输出它们的中位数,答案四舍五入保留 111 位小数。 输入格式 输入共 111 行 444 个正整数 a,b,c,da,b,c,da,b,c,d。 输出格式 输出共 111 行 111 个浮点数表示答案。 样例 #1 样…

[激光原理与应用-259]:理论 - 几何光学 - 平面镜的反射、平面透镜的折射、平面镜的反射成像、平面透镜的成像的规律

一、平面镜的反射规律平面镜的反射遵循镜面反射定律,即光线在光滑表面(反射面平整度远大于波长)发生反射时,满足以下条件:反射光线、入射光线与法线共面:反射光线、入射光线和法线(垂直于反射面…

相机按键功能解析

相机按键功能解析佳能相机按键机身背面机身正面机身顶部机身侧面 佳能相机按键 机身背面取景器目镜:用于拍摄时观察相机形成的图像。实拍显示/视频拍摄按钮:按下即可开始拍摄或录制视频。光圈/曝光补偿键:调整光圈大小和曝光补偿,…

51单片机-驱动LED模块教程

本章思维导图: 51单片机驱动LED灯模块 LED灯元器件简介 LED(Light Emitting Diode,发光二极管) 是一种固态半导体器件,通过P-N结中电子与空穴复合直接将电能转化为光能。其核心结构由P型半导体(空穴主导&a…

Git 完全手册:从入门到团队协作实战(2)

Hello大家好&#xff01;很高兴我们又见面啦&#xff01;给生活添点passion&#xff0c;开始今天的编程之路&#xff01; 我的博客&#xff1a;<但凡. 我的专栏&#xff1a;《编程之路》、《数据结构与算法之美》、《C修炼之路》、《Linux修炼&#xff1a;终端之内 洞悉真理…

c语言中堆和栈的区别

1.栈区(stack):由编译器自动分配释放&#xff0c;栈主要用于存储局部变量、函数参数、函数调用和返回信息等。其操作方式类似于数据结构中的栈。 2.堆区(heap):一般由程序员分配释放&#xff0c;若程序员不释放&#xff0c;则可能会引起内存泄漏。注堆和数据结构中的堆栈不一样…

华为实验WLAN 基础配置随练

业务vlan 20 192.168.20.x管理vlan 100 192.168.100.x步骤① 网络互通Core sw:vlan batch 20 100 dhcp enable int vlanif 20IP add 192.168.20.1 24dhcp select interfaceinterface GigabitEthernet0/0/1/2port link-type trunkport trunk pvid vlan 100port trunk allow-pas…

CMake 如何查找 Python2和Python3

问题 在一个CMakeLists.txt文件里面看到了下面的这句话 find_package(Python2 COMPONENTS Interpreter Development NumPy)这个好有趣啊&#xff0c;Python2也是一个C的库吗&#xff0c;也有Python2Config.cmake或者FindPython2.cmake? 回答 find_package(Python2 COMPONENTS …

心灵笔记:刻意练习

心灵笔记&#xff1a;刻意练习提要 所有人都以为“杰出”源于“天赋”&#xff0c;而“天才”却说&#xff1a;我的成就源于“正确的练习”&#xff01; 定义&#xff1a;刻意练习是一种有目的、有方法、能带来能力持续提升的结构化训练方式&#xff0c;它并非简单的重复劳动&a…