码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Python3-excel文档操作(四):利用openpyxl库处理excel表格:将数据进行可视化展示在Excel中


    1.简介:

    openpyxl不仅提供了将数据一行列的形式对应到Excel表格中,以及相关的添加,删除,获取等操作; 还提供了将数据进行图形化展示的相关组件(类),使得数据图形化在excel表格中的展示变得更加简单。

    2.举例:

    将数据在excel中进行图形化展示(例:公司近几年销售额和利润的数据图形化):

    相关代码如下:

    openxls_chart.py:

    1. # -*- coding: utf-8 -*-
    2. import os
    3. import sys
    4. from openpyxl import Workbook
    5. from openpyxl.chart import BarChart, Series, Reference
    6. from copy import deepcopy
    7. #初始化Workbook
    8. wb = Workbook(write_only=True)
    9. ws = wb.create_sheet()
    10. #创建数据
    11. rows = [
    12. ('年份', '营业额', '利润'),
    13. (2016, 20, 8),
    14. (2017, 30, 12),
    15. (2018, 50, 20),
    16. (2019, 60, 25),
    17. (2020, 70, 35),
    18. (2021, 80, 40),
    19. ]
    20. #添加数据到excel
    21. for row in rows:
    22. ws.append(row)
    23. #chart图的生成1
    24. chart1 = BarChart()
    25. chart1.type = "col"
    26. chart1.style = 10
    27. chart1.title = "近几年营业额/利润对比图"
    28. chart1.y_axis.title = '数据'
    29. chart1.x_axis.title = '年份'
    30. data = Reference(ws, min_col=2, min_row=1, max_row=7, max_col=3)
    31. cats = Reference(ws, min_col=1, min_row=2, max_row=7)
    32. chart1.add_data(data, titles_from_data=True)
    33. chart1.set_categories(cats)
    34. chart1.shape = 4
    35. ws.add_chart(chart1, "A10")
    36. #chart图的生成2
    37. chart2 = deepcopy(chart1)
    38. chart2.style = 11
    39. chart2.type = "bar"
    40. chart2.title = "近几年营业额/利润对比图"
    41. ws.add_chart(chart2, "J10")
    42. #chart图的生成3
    43. chart3 = deepcopy(chart1)
    44. chart3.type = "col"
    45. chart3.style = 12
    46. chart3.grouping = "stacked"
    47. chart3.overlap = 100
    48. chart3.title = "近几年营业额/利润对比图"
    49. ws.add_chart(chart3, "A27")
    50. #chart图的生成4
    51. chart4 = deepcopy(chart1)
    52. chart4.type = "bar"
    53. chart4.style = 13
    54. chart4.grouping = "percentStacked"
    55. chart4.overlap = 100
    56. chart4.title = "近几年营业额/利润对比图"
    57. ws.add_chart(chart4, "J27")
    58. #保存文件
    59. wb.save("bar.xlsx")

    运行结果:

    % python3 openxls_chart.py

    生成了bar.xlsx,打开该excel文件,内容如下:

     

    说明:

    (1)BarChart:用于创建柱状图;

    (2)deepcopy: 用于深度copy,即将已存在的对象的内容全部复制到新的同类型的对象中;

    (3)Workbook相关操作:

        wb = Workbook(write_only=True)
        ws = wb.create_sheet()

        wb.save("bar.xlsx"):保存excel表格。

     


     

  • 相关阅读:
    2024年6月 青少年python三级等级考试真题试卷
    20220917使用迅雷和python3脚本下载ts格式的视频切片文件的速度对比
    Linux——进程间通信(共享内存)
    【Spring】spring管理第三方资源;加载Properties文件
    自定义反序列化类将LocalDate时间格式转为 LocalDateTime
    Linux抓包命令
    数字图像处理实验(二)|图像变换(附实验代码和截图)
    【JVM】内存区域划分、类加载机制(双亲委派模型图解)、垃圾回收(可达性分析、分代回收)
    Ubuntu22.04深度学习GPU环境配置:Nvidia CUDA 11.7、cuDNN 8.5 详细解读(20220910)
    25、业务层标准开发(也就是service)
  • 原文地址:https://blog.csdn.net/liranke/article/details/126109482
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号