【EXCEL】SUMIFS多次条件筛选数据

问题案例

有如下两个工作表(Sheet1和Sheet2):

在sheet1中的C2行获得一个结果(项目1的1月收入),是对sheet2中的A列筛选出"项目1"+B列筛选出"202401"而获得对应C列的结果。借助excel的公式如何实现。

Sheet1 - 总览表

项目 收入 1月收入 2月收入
项目1
项目2

Sheet2 - 详细收入记录

项目 年月 收入
项目1 202401 100
项目1 202402 130
项目2 202401 200
项目2 202402 230

目标:在Sheet1中根据项目名称和月份获取对应的收入数据。

解决方法

方法一:使用 INDEXMATCH 函数组合

在Sheet1的C2单元格中,我们可以使用数组公式来匹配项目1在202401月份的收入:

excel 复制代码
=INDEX(Sheet2!C:C, MATCH(1, (Sheet2!A:A="项目1")*(Sheet2!B:B=202401), 0))

输入上述公式后,使用Ctrl + Shift + Enter来确认,Excel会处理它作为一个数组公式。

方法二:使用 SUMIFS 函数

在Sheet1的C2单元格中,可以使用SUMIFS函数来实现相同的目标,而无需输入数组公式:

excel 复制代码
=SUMIFS(Sheet2!C:C, Sheet2!A:A, "项目1", Sheet2!B:B, 202401)

这个公式会返回所有满足条件(项目为"项目1"且年月为"202401")的收入值的总和。

知识点拓展

INDEX 函数

INDEX 函数返回表格中指定单元格的值,或者某个区域中的某个单元格的值。它的基本语法是:

excel 复制代码
=INDEX(数组, 行号, 列号)

MATCH 函数

MATCH 函数搜索指定项在数组中的位置。它的基本语法是:

excel 复制代码
=MATCH(查找值, 查找数组, 匹配类型)

SUMIFS 函数

SUMIFS 函数可以根据一个或多个条件对范围的值求和。它的基本语法是:

excel 复制代码
=SUMIFS(求和范围, 条件范围1, 条件1, 条件范围2, 条件2, ...)

动态数组

在最新版本的Excel中,不需要使用Ctrl + Shift + Enter来创建数组公式,因为它支持动态数组。只需输入公式并按Enter即可。

注意事项

  • 确保在使用公式时正确引用了工作表名和单元格范围。
  • 在使用MATCH函数时,如果数组中没有找到查找值,将返回错误。
  • SUMIFS函数在有多条相同条件的记录时能返回正确的总和,这适用于求和而非单一值的匹配。
相关推荐
时空自由民.3 小时前
vim入门配置教程
编辑器·vim·excel
_院长大人_5 小时前
Java Excel导出:如何实现自定义表头与字段顺序的完全控制
java·开发语言·后端·excel
Cloud_Shy6189 小时前
Python 数据分析基础入门:《Excel Python:飞速搞定数据分析与处理》学习笔记系列(第十一章 Python 包跟踪器 下篇)
前端·后端·python·数据分析·excel
asdzx6711 小时前
使用 C# 打印 Excel 文档(详细教程)
c#·excel
vennnnnnnnnnnnnn11 小时前
Excel 导入原文保留与内联排名配置问题复盘
前端·数据库·excel
anlog12 小时前
Excel返回或设置边框、字体或内部颜色
excel·背景色
工具怪13 小时前
Excel 如何加水印?4种常见使用场景与操作步骤
excel
写了20年代码的老程序员1 天前
Excel 导入导出为什么总是把后端逼成字段搬运工
java·excel
Cloud_Shy6181 天前
Python 数据分析基础入门:《Excel Python:飞速搞定数据分析与处理》学习笔记系列(第十一章 Python 包跟踪器 中篇)
数据库·python·sql·数据分析·excel·web
Metaphor6921 天前
使用 Python 将 Excel 转换为 PDF
python·pdf·excel