轻松实现VBA多条件提取数据库不重复记录 (vba多条件提取不重复数据库)

在日常的工作中,经常会遇到需要从海量数据中提取某些特定条件的数据记录的情况。传统的手动筛选方法显然不仅效率低下,而且容易出现遗漏或错误。这时,我们可以利用VBA编程技术,快速实现多条件查询、筛选、去重等操作,大大提高数据处理效率,减少出错风险。

在本文中,我们将以常见的Excel工作表为例,介绍如何使用VBA编写程序实现多条件提取数据库不重复记录的功能。

我们需要先创建一个数据表格,包含若干行若干列的数据记录。假设该表格包含以下字段信息:

姓名 性别 年龄 居住城市

张三 男 28 北京

李四 女 25 上海

王五 女 30 北京

赵六 男 27 南京

钱七 女 28 北京

周八 女 32 上海

接着,我们需要打开宏编辑器,新建一个模块,进行以下代码编写:

Sub search()

Dim i As Integer

Dim j As Integer

Dim k As Integer

Dim l As Integer

Dim nameArray As Variant

Dim genderArray As Variant

Dim ageArray As Variant

Dim cityArray As Variant

Dim nameStr As String

Dim genderStr As String

Dim ageStr As String

Dim cityStr As String

Dim resultStr As String

Dim rowCnt As Integer

Dim colCnt As Integer

Dim rstRng As Range

Dim curRng As Range

Dim rstArray() As Variant

Dim rstCnt As Integer

rowCnt = 7 ‘ 行数

colCnt = 4 ‘ 列数

‘ 获取搜索条件

nameStr = InputBox(“请输入姓名”)

genderStr = InputBox(“请输入性别”)

ageStr = InputBox(“请输入年龄”)

cityStr = InputBox(“请输入居住城市”)

‘ 将搜索条件转化为数组

nameArray = Split(nameStr, “,”)

genderArray = Split(genderStr, “,”)

ageArray = Split(ageStr, “,”)

cityArray = Split(cityStr, “,”)

‘ 初始化结果数组

ReDim rstArray(rowCnt – 1, colCnt – 1)

rstCnt = 0

‘ 遍历数据表格,进行搜索

For i = 2 To rowCnt

If nameStr “” And Not IsInArray(Cells(i, 1).Value, nameArray) Then

Continue For

End If

If genderStr “” And Not IsInArray(Cells(i, 2).Value, genderArray) Then

Continue For

End If

If ageStr “” And Not IsInArray(Cells(i, 3).Value, ageArray) Then

Continue For

End If

If cityStr “” And Not IsInArray(Cells(i, 4).Value, cityArray) Then

Continue For

End If

‘ 如果符合条件,则将该记录添加到结果数组中

For j = 1 To colCnt

rstArray(rstCnt, j – 1) = Cells(i, j).Value

Next j

rstCnt = rstCnt + 1

Next i

‘ 将结果数组转换为字符串,无重复项

resultStr = “”

For k = 0 To rstCnt – 1

For l = 0 To colCnt – 1

resultStr = resultStr & rstArray(k, l) & vbTab

Next l

resultStr = resultStr & vbCrLf

Next k

MsgBox resultStr

End Sub

‘ 判断一个字符串是否在一个数组中

Function IsInArray(str As String, arr As Variant) As Boolean

Dim i As Integer

For i = LBound(arr) To UBound(arr)

If str = arr(i) Then

IsInArray = True

Exit Function

End If

Next i

IsInArray = False

End Function

上述程序通过输入搜索条件,依次遍历数据表格中的每一行数据记录,对每个记录进行多条件筛选,将符合条件的记录存入结果数组中,然后将结果数组转化为字符串输出,保证输出结果无重复项。

具体运行程序时,我们可以按照以下操作流程:

1. 打开Excel文件,在工作表中输入数据记录;

2. 打开宏编辑器,在模块中编写上述VBA程序;

3. 按下F5键,运行程序;

4. 在对话框中输入搜索条件,点击确定按钮;

5. 当前符合搜索条件的数据记录将输出至对话框中,点击确定按钮即可关闭对话框。

结论

本文介绍了如何利用VBA编程技术,轻松实现多条件提取数据库不重复记录的功能。通过以上方法,我们可以更快速地进行多条件数据筛选、去重等操作,提高了工作效率,减少了出错风险。同时,读者也可以根据自己所需求的数据内容,进行针对性的改动和扩展,以满足更复杂的数据处理需求。

相关问题拓展阅读:

  • vba ,提取不重复值 后统计重复次数,并判断每个不重复值之间的重复次数是否相等
  • Excel表如何通过VB 获取一列中有哪些不重复的项?

vba ,提取不重复值 后统计重复次数,并判断每个不重复值之间的重复次数是否相等

亲,打开你的Excel文件宽腔脊,按“Alt+F11”打开VBA编辑窗口,然后在左侧空白处点击右键,“插入”,“模块”。右侧空白处粘贴下面的代码。关闭VBA窗口。然后按“Alt+F8”打开宏窗口,选择刚插入的宏,点击“执行”。

 

运行后,将新建一个工作簿,存放结果。

 

Sub pc()

Dim d, k

Set d = CreateObject(“Scripting.Dictionary”)

Dim rg As Range, c, r, n As Long

Workbooks.Add

ActiveWorkbook.ActiveSheet.Range(“C1:D1”).Value = Array(“类型”, “颜色”)

With ThisWorkbook.ActiveSheet

    For c = 3 To 4

r = .Cells(Rows.Count, c).End(xlUp).Row

For Each rg In .Cells(4, c).Resize(r – 3)

慎渗    If rg.Value  “” Then d(rg.Value) = d(rg.Value) + 1

Next

  圆码      r = ActiveWorkbook.ActiveSheet.Cells(Rows.Count, c).End(xlUp).Row: n = 1

For Each k In d.keys

n = n + 1

ActiveWorkbook.ActiveSheet.Cells(n, c).Value = k & “-” & d(k)

Next

d.RemoveAll

    Next

End With

Set d = Nothing

End Sub

你这个结果说明了原始的C列和D列没有任何关系呀,对吗?

Excel表如何通过VB 获取一列中有哪些不重复的项?

必须要用VB吗?

最快,最简单亮缓段的方法就是用字典

代码及注释如下:

Sub main()

Set dic = CreateObject(“scripting.dictionary”) ‘后期绑定字典

arr = Range(“A1:A”敬誉 & Range(“A65536”).End(3).Row) ‘将A列非空单元格全部复制给数组arr

For i = 1 To UBound(arr) ‘循环

dic(arr(i, 1)) = “” ‘将A列数组全部放到字典中

Next i

.Resize(dic.Count, 1) = Application.Transpose(dic.keys) ‘将字典中的条目(即A列不重复哪雀值)放到B列中

End Sub

假定数据在A列,用如下VBA程序橡拿:咐碧

Private Sub CommandButton1_Click()

Dim i As Long, k As Long, a$

k = 1

For i = 2 To Range(“A65536”).End(xlUp).Row

If Application.WorksheetFunction.CountIf(Range(“A1:A” & k), Range(“A”梁简搭 & i).Value) = 0 Then

k = k + 1

Range(“A” & k).Value = Range(“A” & i).Value

End If

Next i

Range(“A” & k + 1 & “:A” & i).ClearContents

End Sub

关于vba多条件提取不重复数据库的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。

香港服务器首选树叶云,2H2G首月10元开通。
树叶云(www.IDC.Net)提供简单好用,价格厚道的香港/美国云服务器和独立服务器。IDC+ISP+ICP资质。ARIN和APNIC会员。成熟技术团队15年行业经验。

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/305841.html<

(0)
运维的头像运维
上一篇2025-05-26 09:21
下一篇 2025-05-26 09:22

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注