使用VBA实现快速模糊查询数据
实例需求:基础数据保存在Database工作表中,如下图所示。

基础数据有37个字段,上图仅展示部分字段内容,下图中黄色字段为需要提取的数据字段。

在Search工作表B1单元格输入查询关键字Title和Genre字段中搜索关键字,包含关键字的数据提取到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行代码将查询结果保存在工作表中。
相关文章:
使用VBA实现快速模糊查询数据
实例需求:基础数据保存在Database工作表中,如下图所示。 基础数据有37个字段,上图仅展示部分字段内容,下图中黄色字段为需要提取的数据字段。 在Search工作表B1单元格输入查询关键字Title和Genre字段中搜索关键字,包…...
spring boot flowable多人前加签
1、前加签插件 package com.xxx.flowable.cmd;import com.xxx.auth.security.user.SecurityUser; import com.xxx.commons.ApplicationContextHolder; import com.google.common.collect.Lists; import org.apache.commons.collections.CollectionUtils; import org.apache.co…...
结构体运算符重载
1.降序 struct Point{int x, y;//重载比较符bool operator < (const Point &a) const{return x > a.x;//当前元素大时,是降序} };2.升序 struct Point{int x, y;//重载比较符 // bool operator < (const Point &a) const{ // return x…...
幽默直观的文档作者注释
注释是程序中非常重要的一部分,在不同的编程语言中,注释的风格和语言描述会有所不同。以下是一些常用的注释风格和语言描述: 直观注释:这种注释使用简洁、明了的语言,帮助读者快速地理解代码。例如,代码中…...
前端开发网站推荐
每个人都会遇见那么一个人,永远无法忘却,也永远不能拥有。 以下是一些可以用来查找和比较前端框架的推荐网站: JavaScript框架比较: 这些网站提供了对不同JavaScript框架和库的详细比较和评估。 JavaScripting: 提供了大量的JavaS…...
【C语言】通讯录管理系统(保姆级教程+内含源码)
C系列文章目录 目录 C系列文章目录 前言 一,模块化编程 二,系统框架构建 1.成员信息的创建 2.菜单实现 3.系统功能声明 三、系统功能实现 1.初始化通讯录 2.增加联系人 3.显示所有联系人 4.根据姓名查找位置 5.删除指定联系人 6.查找指定联…...
python自动解析301、302重定向链接
嗨喽~大家好呀,这里是魔王呐 ❤ ~! python更多源码/资料/解答/教程等 点击此处跳转文末名片免费获取 使用模块requests 方式代码如下: import requests url_string"http://******" r requests.head(url_string, streamTrue) print r.h…...
【未解决问题】opencv 交叉编译 ffmpeg选项始终为NO
opencv 打不开视频的原因 在交叉编译时候,发现在 pc 端能用 opencv 打开的视频,但是在 rv1126 上打不开。在网上查了很久,原因可能是 ffmpeg 造成的。 解决opencv源代码编译找不到ffmpeg-CSDN博客 交叉编译 ffmpeg 尝试了一天还是第二个博客…...
Python实用技术二:数据分析和可视化(2)
目录 一,多维数组库numpy 1,操作函数: 2,numpy数组元素增删 1)添加数组元素 2)numpy删除数组元素 3)在numpy数组中查找元素 4)numpy数组的数学运算 3,numpy数…...
24Hibench
1. Hibench 官网 HiBench is a big data benchmark suite that helps evaluate different big data frameworks in terms of speed, throughput and system resource utilizations. It contains a set of Hadoop, Spark and streaming workloads, including Sort, WordCou…...
VC++父进程交互式操作子进程标准输入输出
父进程接管子进程的标准输入输出和错误,实现对子进程的交互操作。比如子进程是一个类似mysql这种可以交互的命令,执行操作后输出结果,父进程根据结果分析决定执行下一步的命令,从而替代人工的输入。 通过父进程创建子进程,使用管道重定向子进程的输入输出错误可以实现 在 …...
一步一招,教你如何制作出成功的优惠促销微传单
在当今的数字化时代,几乎所有的事情都可以在互联网上完成,包括制作宣传单。有很多在线工具可以帮助我们轻松制作出精美的商场促销宣传单。下面就以乔拓云为例,详细介绍如何简单几步制作出让人眼前一亮的商场促销宣传单。 1. 注册并登录乔拓云…...
27、Flink 的SQL之SELECT (Pattern Recognition 模式检测)介绍及详细示例(7)
Flink 系列文章 1、Flink 部署、概念介绍、source、transformation、sink使用示例、四大基石介绍和示例等系列综合文章链接 13、Flink 的table api与sql的基本概念、通用api介绍及入门示例 14、Flink 的table api与sql之数据类型: 内置数据类型以及它们的属性 15、Flink 的ta…...
Git使用【上】
欢迎来到Cefler的博客😁 🕌博客主页:那个传说中的man的主页 🏠个人专栏:题目解析 🌎推荐文章:题目大解析3 前言 先前有些git命令我在我的其它文章里面已经写过,若要查看可参考【Linu…...
flink的序列化基准测试
背景: flink提供了在本地环境使用jmh测试不同序列化方法的性能差异,本文就是基于这个https://github.com/apache/flink-benchmarks这个性能测试,总结几个结论,以便后面使用时避免掉坑 基准测试 我们本次运行的是SerializationF…...
Error: node: unknown or unsupported macOS version: :dunno 错误解决
一、原因 今天安装 brew install node报错了,错误信息如下: 二、解决方案 1)查找homebrew-cask安装位置 echo $(brew --repo homebrew/homebrew-cask) // 输出 /opt/homebrew/Library/Taps/homebrew/homebrew-cask2)使用 gi…...
嵌入式Linux应用开发-基础知识-第十八章系统对中断的处理②
嵌入式Linux应用开发-基础知识-第十八章系统对中断的处理② 第十八章 Linux系统对中断的处理 ②18.3 Linux中断系统中的重要数据结构18.3.1 irq_desc数组18.3.2 irqaction结构体18.3.3 irq_data结构体18.3.4 irq_domain结构体18.3.5 irq_chip结构体 18.4 在设备树中指定中断_在…...
Kolmogorov-Smirnov正态性检验
Kolmogorov-Smirnov正态性检验是一种统计方法,用于检验数据集是否服从正态分布。其基本原理和用途如下: 基本原理: 假设检验:Kolmogorov-Smirnov检验基于一个假设,即待检验的数据集服从特定的理论正态分布。计算累积…...
BI神器Power Query(25)-- 使用PQ实现表格多列转换(1/3)
实例需求:原始表格包含多列属性数据,现在需要将不同属性分列展示在不同的行中,att1、att3、att5为一组,att2、att3、att6为另一组,数据如下所示。 更新表格数据 原始数据表: Col1Col2Att1Att2Att3Att4Att5Att6AAADD…...
windows系统一键开启和关闭虚拟化
说明 跟虚拟化相关的三个程序 一键开启脚本 REM 开启 Hyper-V 服务 pushd "%~dp0"dir /b %SystemRoot%\servicing\Packages\*Hyper-V*.mum >hyper-v.txtfor /f %%i in (findstr /i . hyper-v.txt 2^>nul) do dism /online /norestart /add-package:"%Sy…...
不只是连线:用立创EDA做PCB布局时,这5个提升电路板可靠性的细节你注意了吗?
不只是连线:用立创EDA做PCB布局时,这5个提升电路板可靠性的细节你注意了吗? 在电子设计领域,PCB布局的质量往往决定了产品的最终表现。许多工程师能够完成基本的电路连接,却容易忽视那些看似微小却至关重要的设计细节。…...
权威榜单|2026年新手必选无人机推荐
推荐1:博坦ATOM2S产品概述与核心亮点博坦ATOM2S是一款专为新手用户设计的无人机,具有简单易用的操作系统和智能飞行功能。其搭载高清摄像头,可以拍摄高质量的4K视频,满足用户对画质的基本需求。ATOM2S还配备了智能跟随、航点飞行等…...
AI研究代理:聚合真实用户行为,打破信息孤岛,实现智能信息整合
1. 项目概述:一个由真实用户行为驱动的AI研究代理如果你和我一样,每天需要快速了解一个陌生的人、公司、技术或者热点事件,你肯定也厌倦了在十几个浏览器标签页之间反复横跳。Google搜索的结果,往往是被SEO优化过的、几个月前的博…...
量子噪声控制与FIR滤波器应用解析
1. 量子噪声控制基础与FIR滤波器原理量子计算的核心挑战之一是如何在噪声环境中保持量子态的相干性。量子比特极易受到环境噪声的影响,导致量子门操作精度下降。在众多噪声类型中,1/f噪声(低频噪声)因其普遍存在于固态量子系统中而…...
FDS火灾模拟实战指南:从物理原理到工程决策
FDS火灾模拟实战指南:从物理原理到工程决策 【免费下载链接】fds Fire Dynamics Simulator 项目地址: https://gitcode.com/gh_mirrors/fd/fds 当面对复杂建筑空间的火灾安全设计时,你是否曾困惑于如何选择合适的模拟工具?如何验证消防…...
基于KNOWM忆阻器的癫痫检测系统设计与实现
1. 项目概述作为一名长期从事神经形态计算研究的工程师,我对忆阻器这一新兴电子元件充满热情。KNOWM忆阻器因其独特的电阻记忆特性和非线性信号处理能力,在储层计算领域展现出巨大潜力。本文将详细探讨我们团队开发的基于KNOWM忆阻器的癫痫检测系统&…...
C语言中的strchr函数
strchr是string.h库中的函数,它的形式为: char * strchr (char * str, int character );功能: 返回一个指针,指向字符在 C 字符串 str 中第一次出现的位置。C 字符串末尾的空字符 \0 被视为字符串的一部分。因此,你也可…...
黑苹果EFI配置终极指南:3步实现完美macOS安装
黑苹果EFI配置终极指南:3步实现完美macOS安装 【免费下载链接】Hackintosh Hackintosh long-term maintenance model EFI and installation tutorial 项目地址: https://gitcode.com/gh_mirrors/ha/Hackintosh 如果你正在寻找一个简单高效的黑苹果EFI配置解决…...
Spring Boot项目对接公司AD域,手把手搞定用户登录和密码重置(附SSL证书避坑指南)
Spring Boot企业级AD域集成实战:从登录到密码重置的全链路解决方案 当企业IT系统发展到一定规模,统一身份认证就成了刚需。上周我接手了一个内部ERP系统的改造项目,要求对接公司Active Directory实现员工单点登录——听起来简单,但…...
Oracle 迁移 PostgreSQL 踩坑:ROWNUM 与 DISTINCT 执行顺序差异导致 SQL 结果不一致
文章目录引言:一次诡异的"数据丢失"排查一、现象复现:同样的 SQL,不同的结果在 KES / Oracle 中的执行过程在 PostgreSQL 中的执行过程二、原理剖析:执行优先级的致命差异2.1 KES / Oracle:ROWNUM 的"先…...
