You need to enable JavaScript to run this app.
最新活动
大模型
产品
解决方案
定价
生态与合作
支持与服务
开发者
了解我们

Excel课程多类别匹配需求:需用公式标记匹配项为X

解决Excel中多类别课程匹配标记问题

嘿,这个需求我之前帮同事处理过,给你两个简单直接的公式方案,刚好能搞定一个课程对应多个类别的场景,你可以根据自己的表结构选:

先明确假设的表结构(你可以根据实际调整)

  • 「原始数据」工作表:A列存课程名称,B列是对应的类别,同一课程可能出现在多行,对应不同类别
  • 「去重课程」工作表:A列是去重后的课程列表,B1、C1...这些表头是所有可能的类别,需要在课程和类别交叉的单元格标记"X"

方案1:用COUNTIFS快速标记匹配项

在「去重课程」的B2单元格(第一个课程对应第一个类别的位置)输入下面的公式:

=IF(COUNTIFS(原始数据!$A:$A,$A2,原始数据!$B:$B,B$1)>0,"X","")

输入完按回车,然后把这个公式横向拖动到所有类别列,再纵向拖动到所有课程行就搞定了。

为啥这个好用?
COUNTIFS会同时检查「原始数据」里是否存在当前课程($A2)和当前类别(B$1)的组合,只要有至少一条匹配记录,就返回"X",完美支持一个课程对应多个类别——每个匹配的类别都会被标上X。

优化小技巧

如果你的数据量特别大(比如上千条记录),用整列引用($A:$A)可能会有点卡顿,建议改成实际的数据范围,比如把原始数据!$A:$A换成原始数据!$A$2:$A$1000(根据你实际的行数调整)。

方案2:动态数组版(适用于Excel 365/2021)

如果你用的是支持动态数组的Excel版本,可以一次性生成所有标记,不用手动拖动:
在「去重课程」的B2单元格输入:

=BYROW($A2:$A100,LAMBDA(course, BYCOL(B$1:Z$1,LAMBDA(cat, IF(COUNTIFS(原始数据!$A:$A,course,原始数据!$B:$B,cat)>0,"X","")))))

这个公式会自动遍历所有课程和类别,生成完整的标记矩阵,省得手动拖拽。

内容的提问来源于stack exchange,提问作者tbreck11

火山引擎 最新活动