【excel】设置可变下拉菜单(一级联动下拉菜单)

文章目录

【需求】制作动态下拉菜单,显示无重复的"班级"列表

原始数据明细如下:

制作下拉菜单,显示所有班级名称,且不重复:

【思路】设置辅助列,使用UNIQUE()函数去重,并用FILTER()去掉结果中的"0"

【步骤】

step1 辅助列

在M1单元格中输入公式=UNIQUE(FILTER($A$2:$A$100,$A$2:$A$100<>""))

本例中选择的范围是前100行。因为下拉菜单中不含有表头,所以从第二行,也就是A2单元格开始。

输入公式后直接回车

注意,虽然公式中含有数组,但不需要使用数组公式的快捷键Ctrl+Shift+Enter输出结果。

step2 设置下拉菜单

在想放置下拉菜单的地方先输入表头,如在H1单元格中输入"班级"。然后鼠标选中H2作为下拉菜单的单元格。

在H2单元格被激活后,【数据】-【数据验证】-【数据验证(V)...】:

在【数据验证】对话框中,【设置】选项卡下,允许(A):选择【序列】,来源:输入=OFFSET($M$1,0,0,COUNTA($M:$M))

这里OFFSET函数返回一个与M列非空单元格数量相同高度的区域(这个高度可变),但宽度只有一列(即M列)。

点击【确定】,完成。

【总结】

1、用UNIQUE()函数制作辅助列,其中FILTER()函数用来消除UNIQUE()函数结果中的"0"。

然后在用"数据验证"生成下拉菜单时,使用OFFSET()函数,引用辅助列。

2、非常重要的是,所谓"辅助列",其实是"辅助单元格"。因为在写UNIQUE()函数时,是用到了数组,但是又不用数组显示出来,因为不能用快捷键Ctrl+Shift+Enter,而是将结果直接回车放在了单元格M1中。

如果使用快捷键Ctrl+Shift+Enter,则在改变A列里面的数据时,下拉菜单将变得不准确,如O列和P列所示:

这是因为Ctrl+Shift+Enter将结果变成固定的列数了。

以上。

相关推荐
herinspace3 小时前
如何解决管家婆辉煌零售POS中显示的原价和售价不一致?
网络·人工智能·学习·excel·语音识别·零售
l1t7 小时前
duckdb excel插件和rusty_sheet插件在python中的不同表现
开发语言·python·excel
agilearchitect8 小时前
Matlab导入Excel表格教程:从基础到进阶全攻略
数据结构·其他·matlab·excel
AC赳赳老秦8 小时前
OpenClaw与Excel联动:批量读取/写入数据,生成可视化报表
开发语言·python·excel·产品经理·策略模式·deepseek·openclaw
做cv的小昊8 小时前
【TJU】研究生应用统计学课程笔记(4)——第二章 参数估计(2.1 矩估计和极大似然估计、2.2估计量的优良性原则)
人工智能·笔记·考研·数学建模·数据分析·excel·概率论
火星papa9 小时前
C# 【通过NPIO读写Excel表】
c#·excel·npoi
葡萄城技术团队9 小时前
Excel公式前的“@”符号:是Bug还是黑科技?
科技·bug·excel
爱折磨键盘的大鹏9 小时前
若依框架实现Excel动态下拉(查库)
excel
Omics Pro1 天前
华大等NC|微生物多样性与抗菌物质发现
大数据·人工智能·深度学习·语言模型·excel
愚公搬代码1 天前
【愚公系列】《OpenClaw实战指南》012-分析与展示:一句话生成可发给老板的报表与 PPT(Excel/WPS 表格自动化处理)
人工智能·自动化·powerpoint·excel·飞书·wps·openclaw