Excel文档的读取(3)

news/2024/9/18 7:35:10/ 标签: java, 前端, python

我们继续观察“销售订单数据”这张工作表。这张表里的每一行其实就是一个订单。
下一步,我们需要在工作表里,逐行去判断哪些订单商品是“火龙果可乐”,并把对应的订单总价添加到当月售卖总金额里。
此处,我们需要用到行数据的遍历

遍历orderSheet中所有的行数据,并使用print输出到终端

在遍历工作表之前,定义一个变量colaSold用来表示当月“火龙果可乐”的销售金额

刚才我们使用行遍历读取出了工作表中的每一行数据。
接下来,我们需要在行遍历中逐行去判断哪些订单商品是“火龙果可乐”,并把对应的订单总价添加到当月售卖总金额里。
首先我们定义一个变量colaSold,用来表示当月“火龙果可乐”的销售金额,并赋值为0。

# 导入openpyxl模块

import openpyxl

# 读取工作目录里名为"2019年1月销售订单.xlsx"的工作簿并赋值给变量wb

wb = openpyxl.load_workbook("2019年1月销售订单.xlsx", data_only=True)

# 通过工作簿对象wb获取名为“销售订单数据”的工作表对象,并赋值给变量orderSheet

orderSheet = wb["销售订单数据"]

# 定义一个变量colaSold用来表示本月“火龙果可乐”的销售金额,并赋值为0

colaSold = 0

# 遍历工作表的所有行数据

for rowData in orderSheet.rows:

    print(rowData)

接下来,我们需要让程序判断表单中每一行的订单商品名是否为“火龙果可乐”。如果是,就逐一把销售金额添加到colaSold变量里。
通过观察“销售订单数据”工作表,我们知道商品名对应的是第C列

通过前面的学习可以发现,行遍历的输出结果,是由单元格对象组成的元组。
在元组中要定位到具体的列不能使用列号“C”,而需要用索引。 我们可以通过肉眼观察,来确定商品名的列“C”是第3列,所以索引是2。
获取每一行商品名的代码如下:productName = rowData[2].value

如果要定位的列数字比较大,比如订单的总价在第M列,通过肉眼观察来确定索引略显繁琐。
这时,可以使用函数:openpyxl.utils.cell.column_index_from_string(),来获取列号对应的数字,比如传入参数“E”就会获取到数字5,表示“E”列是第5列。这个数字减一即可得到对应的索引。因为索引是从0开始的,所以需要减一。

获取每一行订单总价的代码如下:

# 导入openpyxl模块

import openpyxl

# 添加data_only=True打开工作簿,获取公式计算后的值

wb = openpyxl.load_workbook("2019年1月销售订单.xlsx", data_only=True)

# 通过工作簿对象wb获取名为“销售订单数据”的工作表对象,并赋值给变量orderSheet

orderSheet = wb["销售订单数据"]

# 定义一个变量colaSold用来表示本月“火龙果可乐”的销售金额

colaSold = 0

# 遍历工作表的所有行数据

for rowData in orderSheet.rows:

    # 通过索引2获取第3列数据,也就是商品名

    productName = rowData[2].value

    # 获取订单总价M列的索引总和,这里之所以-1是因为需要将表头去除

    priceIndex = openpyxl.utils.cell.column_index_from_string("M") - 1

    price = rowData[priceIndex].value

    # 输出价格

print(price)

# 导入openpyxl模块

import openpyxl

# 使用openpyxl.load_workbook()函数读取工作目录里名为"2019年10月销售订单.xlsx"的工作簿并赋值给变量wb

# 记得添加data_only=True参数打开工作簿,获取公式计算后的值

wb = openpyxl.load_workbook("2019年10月销售订单.xlsx", data_only=True)

# 通过工作簿对象wb获取名为“销售订单数据”的工作表对象,并赋值给变量orderSheet

orderSheet = wb["销售订单数据"]

# 定义一个变量chipsSold用来表示本月“榴莲味薯片”的销售金额

chipsSold = 0

# 遍历工作表的所有行数据

for rowData in orderSheet.rows:

    # 获取这一行的商品名赋值给变量productName

    # 商品名C列是第3列,索引也就是2,记得添加.value读取单元格的值

    productName = rowData[2].value

    # 获取订单总价I列的索引

    priceIndex = openpyxl.utils.cell.column_index_from_string("I") - 1

    # 根据索引获取本行订单总价并赋值给变量price

    price = rowData[priceIndex].value

   

    # 判断productName是否是“榴莲味薯片”,如果是,就逐个添加到本月销售额(chipsSold)里

    if productName == "榴莲味薯片":

        chipsSold = chipsSold + price

# 打印出本月销售额,格式为:2019年10月榴莲味薯片销售额为{销售总额}元

print(f"2019年10月榴莲味薯片销售额为{chipsSold}元")

在明天的课程中,我们将继续完成剩下的2个步骤:

1. 重复执行今天学到的方法,计算出所有12个月的销售额。

2. 找出这12个月里销售额的最大值,然后锁定其对应的月份。

最终解决阿珍的问题:
“火龙果可乐”哪个月份的销售额最高?
 


http://www.ppmy.cn/news/1525118.html

相关文章

iOS 15推出后利用邮件打开率的7种方法

自从苹果在2021年底推出iOS 15以来,邮件打开率就一直是一个让人头疼的指标。 Klaviyo市场情报主管Mindy Regnell表示:“对于启用了Apple邮件隐私保护(MPP)的用户来说,苹果会打开这些邮件并预先下载内容到他们的服务器…

vue3使用leaflet+trackplayer实现非地图动画轨迹(市场平面图动态轨迹)

vue3使用leaflettrackplayer实现非地图动画轨迹(市场平面图动态轨迹) 先下载 leaflet 和 leaflet-trackplayer两个主要库 leaflet官方文档 npm install leaflet npm install leaflet-trackplayer然后在页面中引用 html <template><button click"playMap&quo…

代码随想录打卡Day29

今天的题目尊嘟好难…除了第三题没看视频&#xff0c;其他的题目都是看了视频才做出来的。二刷等我。 134. 加油站 感觉这道题和之前的53. 最大子序和有点像&#xff0c;最大子序和是一旦当前总和为负数则立即抛弃当前的总和&#xff0c;从下个位置重新开始计算&#xff0c;而…

深入剖析 MQTT 协议:物联网通信的核心力量

摘要&#xff1a; 本文全面深入地探讨了 MQTT&#xff08;Message Queuing Telemetry Transport&#xff09;协议。详细阐述了 MQTT 协议的起源与发展背景&#xff0c;介绍其基本概念、特点及工作原理。深入分析了 MQTT 的架构组成&#xff0c;包括客户端、代理服务器及主题的作…

HivisionIDPhotos

在服务器Ubuntu22.04系统下&#xff0c;HivisionIDPhotos的部署 一、安装环境&#xff1a;ubuntu基本环境配置1.更新包列表&#xff1a;2. 安装GPU驱动程序3.查看显卡信息4.下载并安装 CUDA 12.3 二、安装miniconda环境1. 下载miniconda32. 安装miniconda33. 打开用户环境编辑页…

【IP协议】IP协议报头结构(上)

IP 协议报头结构 4位版本 实际上只有两个取值 4 > IPv4&#xff08;主流&#xff09;6 > IPv6 IPv2&#xff0c;IPv5 在实际中是没有的&#xff0c;可能是理论上/实验室中存在 4位首部长度 IP 协议报头也是变长的&#xff0c;因为选项个数不确定&#xff0c;所以报头长…

apifox 调试接口问题

解决laravel 表单验证时出现的404。只要是不通过验证就会出现404。主要是调用闭包函数内的fail函数。就会出现404 $request->validate([name>[required,function($attributes,$value,$fail)use ($user){if(!$user){$fail(User not found);}}],]); 调试工具会出现404. 解…

数据库导入

1.在导入数据库之前&#xff0c;需要数据库存在&#xff0c;才能导入数据&#xff0c;如果不存在需要创建同名的数据库&#xff1a; 创建数据库命令&#xff1a;sudo mysql -u root -p123456 -e CREATE DATABASE public_database; "public_database" :为数据库名称。…

代码随想录训练营第29天|控制变量

134. 加油站 class Solution { public:int canCompleteCircuit(vector<int>& gas, vector<int>& cost) {int cur0, total0, start0;for(int i0; i<gas.size(); i){curgas[i]-cost[i];totalgas[i]-cost[i];if(cur<0){starti1;cur0;}}if(start>gas…

UDP协议对比普通协议有什么优势

在网络通信中&#xff0c;传输控制协议&#xff08;TCP&#xff09;和用户数据报协议&#xff08;UDP&#xff09;是两种最常用的传输层协议&#xff0c;它们在数据传输中扮演着不同的角色&#xff0c;适用于不同的场景。TCP以其可靠性和顺序传输著称&#xff0c;而UDP则以速度…

【Kubernetes】常见面试题汇总(七)

目录 20.简述 Kubernetes 创建一个 Pod 的主要流程&#xff1f; 21.简述 Kubernetes 中 Pod 的重启策略&#xff1f; 20.简述 Kubernetes 创建一个 Pod 的主要流程&#xff1f; Kubernetes 中创建一个 Pod 涉及多个组件之间联动&#xff0c;主要流程如下&#xff1a; &#…

[3.4]【机器人运动学MATLAB实战分析】PUMA560机器人正运动学MATLAB计算

PUMA560是六自由度关节型机器人,其6个关节都是转动副,属于6R型操作臂。各连杆坐标系如图1,连杆参数如表1所示。 图1 PUMA560机器人的各连杆坐标系 表1 PUMA560机器人的连杆参数 按D-H方法建立操作臂运动学方程。建立PUMA560机器人运动学方程的步骤如下࿱

利用熵权法进行数值评分计算——算法过程

1、概述 在软件系统中&#xff0c;研发人员常常遇上需要对系统内的某种行为/模型进行评分的情况。例如根据系统的各种漏洞情况对系统安全性进行评分、根据业务员最近操作系统的情况对业务员工作状态进行打分等等。显然研发人员了解一种或者几种标准评分算法是非常有利于开展研…

【即时通讯】轮询方式实现

技术栈 LayUI、jQuery实现前端效果。django4.2、django-ninja实现后端接口。 代码仓 - 后端 代码仓 - 前端 实现功能 首次访问页面并发送消息时需要设置昵称发送内容为空时要提示用户不能发送空消息前端定时获取消息&#xff0c;然后展示在页面上。 效果展示 首次发送需要…

软件设计师の第三章:数据库技术基础

✨博客主页&#xff1a; https://blog.csdn.net/m0_63815035?typeblog &#x1f497;《博客内容》&#xff1a;.NET、Java.测试开发、Python、Android、Go、Node、Android前端小程序等相关领域知识 &#x1f4e2;博客专栏&#xff1a; https://blog.csdn.net/m0_63815035/cat…

已开源!无限场景生成和高效数据迁移:3D金字塔扩散模型斩获ECCV24 Oral

作者主页&#xff1a; https://yuheng.ink/ 论文标题&#xff1a; Pyramid Diffusion for Fine 3D Large Scene Generation 导读&#xff1a; 本文通过设计一种新颖的金字塔扩散模型&#xff0c;为三维室外场景生成提供了一种从粗到细的策略。本文对金字塔扩散模型进行了大量实…

系统设计文档示例

设计文档示例 文章目录 设计文档示例一、整体架构二、业务或功能-模块设计2.1、需求说明2.2、交互流程2.3、页面设计2.4、功能实现逻辑2.4.1 API设计2.4.2 DB设计 三、 配置说明四、开发示例 一、整体架构 系统架构图简要说明部署架构图简要说明功能模块图简要说明技术架构:前…

Reactive 编程-Loom 项目(虚拟线程)

Reactive 编程与 Loom 项目&#xff08;虚拟线程&#xff09; Java 项目 Loom 是 Oracle 在 JVM 上的一项重大变革&#xff0c;旨在引入 虚拟线程&#xff08;Virtual Threads&#xff09;&#xff0c;以简化并发编程。传统的 Java 线程是重量级的&#xff0c;由操作系统管理&…

深入解析C++单例模式:从基础到线程安全的高效实现

引言 在C开发中&#xff0c;单例模式&#xff08;Singleton Pattern&#xff09; 是一种常见且重要的设计模式。它确保类的实例在整个程序生命周期中唯一&#xff0c;并提供一个全局访问点。这在日志管理、配置管理等场景中尤为常见。本篇博客将带你深入了解单例模式的实现原理…

单例模式的总结

常规模式:有属性/构造方法/普通方法&#xff0c;也可以在类中执行主方法&#xff0c;也可以在test类中执行主方法 单例模式是什么&#xff1f; 单例模式&#xff1a;类只有1个对象&#xff1b;保证一个类仅有一个实例&#xff0c;并提供一个访问它的全局访问点。单例模式是在内…