软件测试|Python操作Excel制作报表,不要太方便
off999 2025-05-15 20:23 21 浏览 0 评论
前言
今天我们介绍的是Python操作Excel制作报表,我们需要用到的库是openpyxl,我们主要使用的功能有下列几个功能
- 插入与查询数据
- 分类数据统计
- 数据可视化
- 字体颜色修改
基本操作
表格初始数据如下图所示:
我们先熟悉一下openpyxl库,方便我们后续更高级的用法
- 安装环境
我们需要安装openpyxl库,安装也很简单,一条命令解决问题,在pycharm中安装也可以,具体方法和安装其他库一致,这里不做赘述
pip install openpyxl
- 导入Excel数据集,代码如下
# 导入模块
from openpyxl import Workbook, load_workbook
# 导入Excel数据集
wb = load_workbook(r"sales.xlsx")
# 得到正在运行的工作表
sheet = wb.active
# 工作表的名称叫做
print(sheet)
-----------
# 输出 <Worksheet "auto_sales">
- 打印出工作表中的值
我们通过传入单元格的位置来打印其中的数值,代码如下
print(sheet["A1"].value)
print(sheet["A2"].value)
print(sheet["B3"].value)
----------------
# 输出
Brand
Vw
Japan
- 修改单元格的值
sheet["C10"] =75
# 保存
wb.save(r"sales.xlsx")
在保存过之后,我们来看一下是否成功修改了单元格的值,如下图所示:
我们看到单元格的值被成功修改了。
- 添加一个工作表
我们可以在现有的Excel文件中添加一个sheet,代码如下:
# 添加一个新的工作表
wb.create_sheet("new_energy_cars_sales")
# 返回以列表形式带有工作表名称
print(wb.sheetnames)
# 输出
['auto_sales', 'new_energy_cars_sales']
注:此处我们没有保存,所以文件中不会出现新的sheet
- 插入数据
我们通过代码新建一个Excel文件,并在文件中写入部分数据
from openpyxl import Workbook, load_workbook
new_wb = Workbook()
ws = new_wb.active
# 重命名工作表的名称
ws.title = "contry"
# 插入数据到新建的工作表中
ws.append(["PRC","is","a","great","contry"])
new_wb.save("contry.xlsx")
我们来看一下最后出来的结果,如下图所示:
我们尝试来多插入几条数据,代码如下:
# 插入更多的数据
ws.append(["USA","Is","a","dirty", "contry"])
ws.append(["UK","is","a","deep", "contry"])
ws.append(["End"])
# 保存
new_wb.save("contry.xlsx")
结果如下:
- 插入行与删除行
插入某一行的话,调用的则是insert_rows()方法,具体代码如下:
# 前面的步骤一样,导入工作簿和数据
ws.insert_rows(1)
new_wb.save("contry.xlsx")
出来的结果如下图所示
同理,如果是想要去删除某一行的数据的话,调用的则是delete_rows()方法,具体代码如下:
ws.delete_rows(1)
# 保存
new_wb.save("contry.xlsx")
查看结果,可以看到插入的行已经被删除
- 插入列与删除列
插入列删除列的操作与插入行删除行的操作类似,插入列用到的方式是insert_cols(),代码如下
# 新插入一列
ws.insert_cols(6)
删除列的方法是delete_cols()
ws.delete_cols(6)
数据分析与可视化
openpyxl是一个非常强大的第三方库,结合Python,Excel能实现的操作,python+openpyxl都可以实现,现在我们就来使用一下稍微高端一些的功能,实现数据的分析和可视化。
1.数据准备
因为手头没有实际的数据,所以现在只能自己随便生成一批数据,不严谨,请大家见谅。
数据如下:
brand_data = {
"大众":{"A级":1200000, "B级":500000, "C级":400000, "D级":30000, "SUV":480000},
"丰田":{"A级":900000, "B级":450000, "C级":240000, "D级":2160, "SUV":300000},
"本田":{"A级":600000, "B级":240000, "C级":160, "D级":0, "SUV":240000},
"比亚迪":{"A级":1080000, "B级":280000, "C级":0, "D级":0, "SUV":300000},
"奔驰":{"A级":0, "B级":180000, "C级": 216000, "D级":60000, "SUV": 120000 }
}
将数据写入Excel,代码如下:
# 创建一个新的工作簿
sales_wb = Workbook()
ws = sales_wb.active
# 重命名工作表的名称
ws.title = "Sales"
# 创建列名
column_names = ["Brand Name"] + list(brand_data["大众"].keys())
ws.append(column_names)
# 将一系列的数值都放置到工作表当中去
for product in brand_data:
sales = list(brand_data[product].values())
ws.append([product] + sales)
sales_wb.save("brand_data.xlsx")
表格如图所示:
- 平均值的计算实现
我们来指定某一列,例如我们要计算各品牌B级车的平均销量,代码如下:
ws['C7'] = '=AVERAGE(C2:C6)'
sales_wb.save("brand_data.xlsx")
结果如下图:
3. 求和的计算实现
我们现在要计算各个品牌的各自的销量总和,该怎样实现,代码如下
min_row = ws.min_row
max_row = ws.max_row
min_col = ws.min_column
max_col = ws.max_column
for row in range(min_row+1,max_row+1):
key=ws.cell(row=row,column=max_col+1).coordinate
#求和的开始单元格地址
start = ws.cell(row=row,column=min_col+1).coordinate
#求和的结束单元格地址
end = ws.cell(row=row,column=max_col-1).coordinate
ws[key]=f'=SUM({start}:{end})'
sales_wb.save('brand_data.xlsx')
结果如下图:
绘制柱状图
来绘制一张柱状图,来看一下不同的品牌不同级别的汽车的销售数据如何,横坐标对应的品牌,而纵坐标对应的则是销量,另外我们根据不同的级别会用不同的颜色来标注出来,代码如下:
from openpyxl.chart import BarChart, Reference
# 新建一个柱状图实例
barchart = BarChart()
# 确定数据的范围
data = Reference(ws, min_col=ws.min_column+1, max_col=ws.max_column, min_row=ws.min_row, max_row=ws.max_row)
categories = Reference(ws, min_col=ws.min_column, max_col=ws.min_column, min_row=ws.min_row+1, max_row=ws.max_row)
# 添加数据以及类目
barchart.add_data(data, titles_from_data=True)
barchart.set_categories(categories)
# 绘制的数据放在哪个位置
ws.add_chart(barchart, "A10")
# 添加标题
barchart.title = '每个品牌的分级别产品销售数据'
# 图表的类型
barchart.style = sales_wb.save("brand_data.xlsx")
结果如图所示:
总结
本文只是对openpyxl强大功能的部分演示,如果大家想学习其他技巧,欢迎评论区留言!
相关推荐
- 云电脑app哪个好(手机云电脑app哪个最好)
-
答:以下是一些比较好的云电脑应用程序推荐:1.AnyDesk-支持Windows、MacOS、Linux、Android和iOS,可用于远程访问和控制PC或移动设备。2.Splashtop...
- 怎样注册邮箱163免费(怎样注册邮箱163免费账号)
-
一、工具:电脑(联网)、浏览器二、操作步骤:【1】打开浏览器,找到“163邮箱”,点击。【2】点击右边的“注册”。【3】网站默认注册手机号码邮箱,填写信息,点击“注册”。若不想泄漏手机号码或不想使用手...
- 微软surface pro 6(微软surface pro 6可以扩容吗)
-
SurfacePro6的接口包含:1个标准尺寸USB3.0端口,3.5mm耳机插孔,MiniDisplayPort,1个SurfaceConnect端口,Surface专业键盘盖端口,microSDX...
- 电源已接通未充电怎么回事(电源已接通未充电 真正解决办法)
-
原因分析:出现这样的原因有可能是长时间没有充电,导致电池的内部电量耗完后亏电严重,只是电脑充电的保护,不让过充而已,只要设置一下电池选项一般就可以解决问题了。解决方法:1、关机,拔下电源,拔出电池,...
- 华为云会议app下载(华为云会议下载)
-
华为云会议可以在PC客户端或者手机客户端上一键发起立即会议,1秒创会。然后在会中选择企业通讯录中的人加入,系统会自动呼叫这些与会人,接听后即加入会议。ZOOM是一个云会议服务平台,为客户提...
- 路由器重置方法(路由器重置方法详细步骤)
-
路由器靠近WAN口边上的有一个小孔用于路由器的重置,路由器配置完成后,我们可能会忘记他的用户名或者是密码,那么我们可以把它恢复到出厂设置,再靠近万口或电源之间,有一个小孔,用一个尖锐的金属查一下大约五...
- 100个有效qq号以及密码(有效qq号和密码大全)
-
如果你的电脑知识好的话,不妨用一些复合密码!SHIFT+一些特殊符号,字母,数字!虽然麻烦了点,但总比被人盗号了的好,是吧!最好还用手机绑定一下,这样的话方便改密码也不怕QQ被盗了哦。。。QQ密码找回...
- win10家庭中文版下载官网(windows10家庭中文版下载)
-
你好,激活Win10家庭中文版的方法:1.购买正版Win10家庭中文版激活码,然后在计算机上输入激活码,即可完成激活。2.如果您已经安装了Win10家庭中文版,但尚未激活,可以通过以下步骤激活:-...
- 电脑截图在哪里找(电脑截图在哪里找图片win10)
-
截图默认会保存在电脑的剪贴板中,可以通过以下步骤将其保存到本地:1.打开任意一款图片软件,如Paint、Photoshop、Word等。2.按下键盘上的Ctrl+V,或者在软件菜单栏中选择...
- 电脑里一堆microsoft visual
-
按照系统向下兼容原理,保留2010就可以了.1)你安装的时候是不是把创建快捷键的选项框都没选上,导致在开始菜单中没有找到相应的链接?2)去你的安装目录下,找到Microsoftvisualc++...
-
- windows无法识别usb(windows无法识别usb设备)
-
Windows无法识别USB,解决办法如下右键开始菜单打开设备管理器,在通用串行总线控制器中右键点击设备选择“卸载”,完成后重新启动计算机即可解决问题。这有可能是在组策略中禁用了USB口,可以使用快捷键【Win+R】运行gpedit.msc...
-
2025-11-10 11:51 off999
- bios能看到硬盘 开机找不到硬盘
-
bios里可以看到硬盘,说明硬盘已经被主板识别。进系统找不到,可能硬盘没分区,或者硬盘是动态磁盘,还没有导入或激活。按win+r,输入diskmgmt.msc回车,就打开磁盘管理了,在里面可以给新硬盘...
- 无线网有个红叉(无线网有个红叉,搜索不到网络)
-
连接失败,路由坏换路由,外网坏,报修无线网络处出现红叉表示设备无法正常工作。请检查网卡驱动是否正常,无线网络开关是否打开。解决方法:查看电脑是否有无线网络开关,且是否打开。进入设备管理器检查网卡驱动是...
- thinkpad笔记本官网首页(thinkpad官方商城)
-
官方网站 国内:http://www.thinkworld.com.cn 国内用户只需要访问国内即可。 ThinkPad,中文名为“思考本”,在2005年以前是IBMPC事业部旗下的便携式计算机...
欢迎 你 发表评论:
- 一周热门
-
-
抖音上好看的小姐姐,Python给你都下载了
-
全网最简单易懂!495页Python漫画教程,高清PDF版免费下载
-
Python 3.14 的 UUIDv6/v7/v8 上新,别再用 uuid4 () 啦!
-
python入门到脱坑 输入与输出—str()函数
-
飞牛NAS部署TVGate Docker项目,实现内网一键转发、代理、jx
-
宝塔面板如何添加免费waf防火墙?(宝塔面板开启https)
-
Python三目运算基础与进阶_python三目运算符判断三个变量
-
(新版)Python 分布式爬虫与 JS 逆向进阶实战吾爱分享
-
慕ke 前端工程师2024「完整」
-
失业程序员复习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写入txt (66)
- python读取文件夹下所有文件 (59)
- python操作mysql数据库 (66)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python多态 (60)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)
