跳至主要内容

如何在Excel的单元格中键入内容时进行即时筛选搜索?

Author: Siluvia Last Modified: 2025-07-31

本文提供了一种方法,让您在Excel单元格中输入内容时能够即时搜索和筛选。

使用VBA代码实现键入时的即时筛选搜索


使用VBA代码实现键入时的即时筛选搜索

如下截图所示,您有一个名称列表,希望在特定单元格中键入内容时能够即时搜索和筛选。请按照以下步骤操作以实现此功能。

sample data

1. 首先,您需要使用列表数据创建一个表格,并将该表格命名为“Name”。请选择整个列表,点击 插入 > 表格。

click Insert > Table

2. 在弹出的 创建表格 对话框中,点击 确定。参见截图:

click OK to create a table

3. 单击表格中的任意单元格以激活 设计 选项卡,然后在 表格名称 文本框中将表格重命名为 Name。参见截图:

 rename the table as Name in the Table Name textbox

4. 点击 开发工具 > 插入 > 文本框(ActiveX 控件),在表格列表上方插入一个文本框,如下截图所示:

Click Developer > Insert > Text Box

5. 右键单击文本框并选择 属性,在 属性 窗口中,在 LinkedCell 框中输入一个单元格引用。

Right click the Text Box and click Properties, then set options in the pane

6. 右键单击文本框并从上下文菜单中选择 查看代码。然后在 Microsoft Visual Basic for Applications 窗口中用以下VBA代码替换原始代码。参见截图:

right click the sheet name and select view code, thne, copy and paste the code into the sheet module

VBA代码:在Excel中键入时即时筛选搜索

Private Sub TextBox1_Change()
'Update by Extendoffice 2018/08/22
Dim xStr, xName As String
Dim xWS As Worksheet
Dim xRg As Range
    On Error GoTo Err01
    Application.ScreenUpdating = False
    xName = "Name"
    xStr = TextBox1.Text
    Set xWS = ActiveSheet
    Set xRg = xWS.ListObjects(xName).Range
    If xStr <> "" Then
        xRg.AutoFilter field:=1, Criteria1:="*" & xStr & "*", Operator:=xlFilterValues
    Else
        xRg.AutoFilter field:=1, Operator:=xlFilterValues
    End If
Err01:
Application.ScreenUpdating = True
End Sub

注意:在代码中,TextBox1 是插入文本框的名称,Name 是表格列表的名称。您可以根据需要更改它们。

7. 按下 Alt + Q 键关闭 Microsoft Visual Basic for Applications 窗口。

通过点击 开发工具 > 设计模式 关闭设计模式。

从现在开始,表格列表将根据文本框中输入的值进行即时搜索和筛选。参见截图:

the table list will be searched and filtered instantly based on the entered value in the text box

a screenshot of kutools for excel ai

使用 Kutools AI 解锁 Excel 魔法

  • 智能执行:执行单元格操作、分析数据和创建图表——所有这些都由简单命令驱动。
  • 自定义公式:生成量身定制的公式,优化您的工作流程。
  • VBA 编码:轻松编写和实现 VBA 代码。
  • 公式解释:轻松理解复杂公式。
  • 文本翻译:打破电子表格中的语言障碍。
通过人工智能驱动的工具增强您的 Excel 能力。立即下载,体验前所未有的高效!

最佳 Office 办公效率工具

🤖 Kutools AI 助手:基于智能执行,彻底革新数据分析 生成代码创建自定义公式分析数据并生成图表调用 Kutools Functions
热门功能:查找、选中项的背景色或标记重复项|删除空行|合并列或单元格且不丢失数据|四舍五入(无公式)...
高级 LOOKUP多条件查找 (VLookup)多值查找 (VLookup)多表查找 (VLookup Across Multiple Sheets)模糊查找 (Fuzzy Lookup)...
高级下拉列表快速创建下拉列表依赖型下拉列表多选下拉列表...
列管理器添加指定数量的列移动列切换隐藏列的可见状态比较区域及列...
特色功能网格聚焦设计视图增强编辑栏工作簿 & 工作表管理器资源库(自动文本)|日期提取合并数据加密/解密单元格按列表发送电子邮件超级筛选特殊筛选(筛选粗体/倾斜/删除线等)...
热门15 大工具集12 款文本工具添加文本删除特定字符等)50+ 种图表 类型甘特图等)40+ 实用公式基于生日计算年龄等)19 款插入工具插入二维码按路径插入图片等)12 种转换工具小写金额转大写汇率转换等)7 款合并与分割工具高级合并行分割单元格等)...更多精彩等你发现
使用 Kutools,支持您的首选语言——包括英语、西班牙语、德语、法语、中文及40 多种其他语言!

用 Kutools for Excel 加速你的 Excel 技能,体验前所未有的高效办公。 Kutools for Excel 提供300 多项高级功能,助您提升效率,节省大量时间。点击此处,获取你最需要的功能...


Office Tab 为 Office 带来标签式界面,让你的工作更加轻松

  • 在 Word、Excel、PowerPoint 启用标签式编辑和阅读
  • 在同一窗口的新标签中打开和创建多个文档,无需新建窗口。
  • 办公效率提升50%,每天帮你减少上百次鼠标点击!