ExcelTip.Net留存知识帖 ---【注:附件之前被网盘供应商清空后,现已修复-现已修复-现已修复为本地下载!】
现在位置:首页 > E问E答 > Excel VBA > 使用字典方式进行条件筛选实例

使用字典方式进行条件筛选实例

作者:绿色风 分类: 时间:2022-08-17 浏览:91
楼主
zzmxy
筛选要求如下图所示,需要筛选两部分内容,分别以D1和H1:H2为筛选条件,对A:C列进行筛选,并将数值从大到小排列,

 


筛选方法:
如D1单元格的条件,刚将B列与D1进行比较,如果B列某个单元格的值等于D1,那么就返回该单元格的下一行的记录,
如B1=D1,则A2:C2就是符合筛选要求的记录,并添加到E:G列,由于其值最小,故放置在最下边;
同理,H1:H2为筛选条件时,则比较B列相邻两个单元格的值是否同时满足,如满足,则返回其下一行的记录,如A3:C3。

---------------------------------
代码如下,主要思路:
- 通过建立字典,并对B列的值进行循环比较,如满足条件,则将该行的下一行作为字典的Key,将B、C列用逗号串接后,作为字典的Item,
- 由于需要从大到小排列,故循环时,直接从大往小,使用Step -1的方式,避免后期再排序;
- 由于B、C列用逗号串接,使用d.Items返回后,需要再以逗号进行分列,使用的语句为:
  1. Columns("F:F").TextToColumns Comma:=True
  2. Columns("J:J").TextToColumns Comma:=True


详细代码如下:
  1. Private Sub Worksheet_SelectionChange(ByVal Target As Range)
  2.     If Target.Address = "$P$2" Then
  3.    
  4.     On Error Resume Next
  5.     Application.ScreenUpdating = False
  6.     Set d = CreateObject("scripting.dictionary")
  7.     Set dd = CreateObject("scripting.dictionary")
  8.     arr = Cells(1, 1).CurrentRegion.Value
  9.     Ct = Cells(1, 4).Text
  10.     CtD1 = Cells(1, "H").Text: CtD2 = Cells(2, "H").Text
  11.     Union(Columns("E:G"), Columns("I:K")).ClearContents
  12.     For i = UBound(arr, 1) To 3 Step -1
  13.         If arr(i - 1, 2) = Ct Then d(arr(i, 1)) = arr(i, 2) & "," & arr(i, 3)
  14.         If arr(i - 2, 2) = CtD1 And arr(i - 1, 2) = CtD2 Then dd(arr(i, 1)) = arr(i, 2) & "," & arr(i, 3)
  15.     Next
  16.     If arr(1, 2) = Ct Then d(arr(2, 1)) = arr(2, 2) & "," & arr(2, 3)
  17.    
  18.     Cells(1, "E").Resize(d.Count, 1) = Application.Transpose(d.keys)
  19.     Cells(1, "F").Resize(d.Count, 1) = Application.Transpose(d.items)
  20.     Cells(1, "I").Resize(dd.Count, 1) = Application.Transpose(dd.keys)
  21.     Cells(1, "J").Resize(dd.Count, 1) = Application.Transpose(dd.items)

  22.     Union(Range("E:E"), Range("I:I")).NumberFormatLocal = "0000"
  23.    
  24.     Application.DisplayAlerts = False
  25.     Columns("F:F").TextToColumns Comma:=True
  26.     Columns("J:J").TextToColumns Comma:=True
  27.     Application.DisplayAlerts = True
  28.     Application.ScreenUpdating = True

  29. End If
  30. End Sub




VBA条件筛选排序实例zz.rar
2楼
亡者天下
筛选还有这么多玩艺啊?

免责声明

有感于原ExcelTip.Net留存知识的价值及部分知识具有的时间限定性因素, 经与ExcelTip.Net站长Apolloh商议并征得其同意, 现将原属ExcelTip.Net的知识帖采集资料于本站点进行展示, 供有需要的人士查询使用,也慰缅曾经的论坛时代。 所示各个帖子的原作者如对版权有异议, 可与本人沟通提出,或于本站点留言,我们会尽快处理。 在此,感谢ExcelTip.Net站长Apolloh的支持,感谢本站点所有人**绿色风(QQ:79664738)**的支持与奉献,特此鸣谢!
------本人网名**KevinChengCW(QQ:1210618015)**原ExcelTip.Net总版主之一

评论列表
sitemap