当前位置: 首页 > news >正文

使用VBA实现快速模糊查询数据

实例需求:基础数据保存在Database工作表中,如下图所示。
在这里插入图片描述
基础数据有37个字段,上图仅展示部分字段内容,下图中黄色字段为需要提取的数据字段。
在这里插入图片描述

Search工作表B1单元格输入查询关键字TitleGenre字段中搜索关键字,包含关键字的数据提取到Search工作表,从第4行开始保存查询结果,如下图所示。
在这里插入图片描述

示例代码如下。

Sub Demo()Dim res(), arr, colsdim lngLstRow as longdim strKey as Stringdim intIndex as Integerdim i as long, j as IntegerlngLstRow = Sheets("Database").Cells(Rows.Count, 1).End(xlUp).Rowarr = Sheets("Database").Range("A2:I" & lngLstRow)ReDim res(1 To lngLstRow, 1 To 6)intIndex = 1cols = Array(1, 3, 5, 7, 8, 9)strKey = Sheets("Search").[b1]For i = 1 To lngLstRow - 1If InStr(1, arr(i, 3) & arr(i, 5), strKey) > 0 ThenFor j = 1 To 6res(intIndex, j) = arr(i, cols(j - 1))NextintIndex = intIndex + 1End IfNextIf intIndex > 1 ThenWith Sheets("Search").Range("4:10000").Clear.Range("A4").Resize(intIndex, 6).Value = resEnd WithEnd If
End Sub

【代码解析】
第7行代码获取基础数据的最后一行所在行号。
第8行代码读取A列到I列数据,由于基础数据字段很多,全部加载到数据中,将占用更多内存,可能导致运行效率下降,因此只加载需要提取部分。
第9行代码重新声明动态数组res用于保存查询结果。
第10行代码设置变量intIndex用于指示数组res中的写入位置。
第11行代码创建数组保存需要提取的列号,这样可以简化提取数据的代码(第15~17行代码)。
第12行代码读取查询关键字。
第13~20行代码循环处理每行数据。
第14行代码判断知道字段是否包含查询关键字,arr(i, 3) & arr(i, 5)将两个字段合并为一个字符串,这样调用一次Instr函数就可以完成查询。
第15~17行代码提取指定的字段,保存到数组res中。
第18行代码变量累加1,指向下一个保存位置。
第22行代码情况保存查询结果单元格区域。
第23行代码判断是否有符合查询添加的结果,如果满足条件,第24行代码将查询结果保存在工作表中。

http://www.lryc.cn/news/180176.html

相关文章:

  • spring boot flowable多人前加签
  • 结构体运算符重载
  • 幽默直观的文档作者注释
  • 前端开发网站推荐
  • 【C语言】通讯录管理系统(保姆级教程+内含源码)
  • python自动解析301、302重定向链接
  • 【未解决问题】opencv 交叉编译 ffmpeg选项始终为NO
  • Python实用技术二:数据分析和可视化(2)
  • 24Hibench
  • VC++父进程交互式操作子进程标准输入输出
  • 一步一招,教你如何制作出成功的优惠促销微传单
  • 27、Flink 的SQL之SELECT (Pattern Recognition 模式检测)介绍及详细示例(7)
  • Git使用【上】
  • flink的序列化基准测试
  • Error: node: unknown or unsupported macOS version: :dunno 错误解决
  • 嵌入式Linux应用开发-基础知识-第十八章系统对中断的处理②
  • Kolmogorov-Smirnov正态性检验
  • BI神器Power Query(25)-- 使用PQ实现表格多列转换(1/3)
  • windows系统一键开启和关闭虚拟化
  • NSSCTF做题(5)
  • java基础题——二维数组的基本应用
  • Leetcode 2119.反转两次的数字
  • BI神器Power Query(27)-- 使用PQ实现表格多列转换(3/3)
  • VUE3照本宣科——认识VUE3
  • 《计算机视觉中的多视图几何》笔记(12)
  • TFT LCD刷新原理及LCD时序参数总结(LCD时序,写的挺好)
  • 基于Java的电影院购票系统设计与实现(源码+lw+部署文档+讲解等)
  • Linux基础指令(六)
  • Anderson-Darling正态性检验【重要统计工具】
  • Ubuntu基于Docker快速配置GDAL的Python、C++环境