0

0

Excel如何利用数据验证制作带模糊搜索功能的下拉菜单_使用动态数组溢出范围

P粉602998670

P粉602998670

发布时间:2026-01-29 15:31:22

|

162人浏览过

|

来源于php中文网

原创

需将源数据转为表格并定义动态命名区域,用FILTER函数实现模糊匹配与自动溢出,再通过数据验证引用溢出区域名称创建可刷新下拉菜单,并优化界面与错误提示。

excel如何利用数据验证制作带模糊搜索功能的下拉菜单_使用动态数组溢出范围

如果您希望在Excel中创建一个支持模糊搜索的下拉菜单,并借助动态数组自动扩展匹配结果,需突破传统数据验证的静态限制。以下是实现该功能的具体步骤:

一、准备源数据与定义动态命名区域

动态数组公式需依托可自动扩展的引用范围,因此必须先将原始列表转为Excel表格(Ctrl+T),并为其指定结构化引用名称,确保后续FILTER函数能响应新增行。此步骤是实现溢出匹配结果的前提基础。

1、选中原始数据列(例如A2:A1000),按Ctrl+T创建为表格,勾选“表包含标题”,确认后表格自动命名为Table1。

2、点击“公式”选项卡 → “定义名称”,在“名称”栏输入SearchList,“引用位置”输入:=Table1[产品名称](假设列标题为“产品名称”)。

3、再次定义名称FuzzyResult,引用位置输入:=FILTER(SearchList,ISNUMBER(SEARCH($D$1,SearchList)),""),其中D1为用户输入的搜索关键词单元格。

二、构建模糊匹配动态溢出区域

FILTER函数将根据D1内容实时返回所有含关键词的条目,并自动向下溢出填充;该溢出区域将成为数据验证下拉菜单的实际来源,替代固定范围引用。

1、在空白列(如F2)输入公式:=FuzzyResult,确认后结果自动纵向填充至所有匹配项。

2、选中F2单元格,观察编辑栏右侧是否出现蓝色溢出边框,若存在,说明动态数组已生效。

3、右键F2 → “定义名称”,新建名称DropdownRange,引用位置设为:=F2#(井号表示整个溢出区域)。

三、设置数据验证引用动态溢出区域

标准数据验证不支持直接引用动态数组公式,但可通过间接引用已定义的溢出名称DropdownRange,使下拉菜单内容随搜索词实时更新。

1、选中需设置下拉菜单的目标单元格(如G2)。

QIMI奇觅
QIMI奇觅

美图推出的游戏行业广告AI制作与投放一体化平台

下载

2、点击“数据”选项卡 → “数据验证” → “数据验证”。

3、在“允许”中选择“序列”,在“来源”框内输入:=DropdownRange,取消勾选“忽略空值”,点击确定。

四、添加搜索触发机制与界面优化

为提升交互体验,需确保用户在D1输入时,下拉菜单立即刷新;同时隐藏辅助列避免干扰,且防止用户误编辑溢出区域。

1、右键F列列标 → “隐藏”,将F列(溢出区域)从视图中移除。

2、选中D1单元格,设置浅灰色底纹与加粗字体,标注提示文字:“请输入关键词”。

3、在G2数据验证单元格旁插入文本框,注明:输入关键词后,点击G2即可显示匹配项下拉列表

五、处理空匹配与错误显示

当FILTER未找到匹配项时返回空字符串,可能导致下拉菜单显示空白项;需用IFERROR包裹并返回占位符,保证验证来源始终有效。

1、修改FuzzyResult名称的引用位置为:=IFERROR(FILTER(SearchList,ISNUMBER(SEARCH($D$1,SearchList))),"无匹配")

2、同步更新DropdownRange名称的引用位置为:=F2#(保持不变,因F2公式已重新计算)。

3、检查G2下拉菜单:当D1输入不存在的词时,应仅显示“无匹配”一项,而非空白或报错。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

298

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

212

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1501

2023.10.24

字符串介绍
字符串介绍

字符串是一种数据类型,它可以是任何文本,包括字母、数字、符号等。字符串可以由不同的字符组成,例如空格、标点符号、数字等。在编程中,字符串通常用引号括起来,如单引号、双引号或反引号。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

624

2023.11.24

java读取文件转成字符串的方法
java读取文件转成字符串的方法

Java8引入了新的文件I/O API,使用java.nio.file.Files类读取文件内容更加方便。对于较旧版本的Java,可以使用java.io.FileReader和java.io.BufferedReader来读取文件。在这些方法中,你需要将文件路径替换为你的实际文件路径,并且可能需要处理可能的IOException异常。想了解更多java的相关内容,可以阅读本专题下面的文章。

633

2024.03.22

php中定义字符串的方式
php中定义字符串的方式

php中定义字符串的方式:单引号;双引号;heredoc语法等等。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

588

2024.04.29

go语言字符串相关教程
go语言字符串相关教程

本专题整合了go语言字符串相关教程,阅读专题下面的文章了解更多详细内容。

171

2025.07.29

c++字符串相关教程
c++字符串相关教程

本专题整合了c++字符串相关教程,阅读专题下面的文章了解更多详细内容。

83

2025.08.07

clawdbot ai使用教程 保姆级clawdbot部署安装手册
clawdbot ai使用教程 保姆级clawdbot部署安装手册

Clawdbot是一个“有灵魂”的AI助手,可以帮用户清空收件箱、发送电子邮件、管理日历、办理航班值机等等,并且可以接入用户常用的任何聊天APP,所有的操作均可通过WhatsApp、Telegram等平台完成,用户只需通过对话,就能操控设备自动执行各类任务。

13

2026.01.29

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Excel 教程
Excel 教程

共162课时 | 14万人学习

成为PHP架构师-自制PHP框架
成为PHP架构师-自制PHP框架

共28课时 | 2.5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号