首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >VBA Scripting.Dictionary过滤问题

VBA Scripting.Dictionary过滤问题
EN

Stack Overflow用户
提问于 2019-02-07 04:59:30
回答 2查看 205关注 0票数 1

嘿,我的脚本字典出了点问题。它应该过滤掉给定的文本,但它也过滤了列中的数值(0,1,2),我希望这些数值都显示出来。

任何帮助都将不胜感激!

代码语言:javascript
复制
'Filter Prefixes
Set arr = CreateObject("scripting.dictionary")
With ActiveSheet
 lr = .Cells(Rows.Count, 1).End(xlUp).Row
 For i = 2 To lr
     Select Case UCase(.Cells(i, "C").Value2)
         Case "NA", "ND", "NH", "NK", "NL", "NQ", "NV"
             'do nothing
         Case Else
             arr.Item(.Cells(i, "C").Value2) = vbNullString
     End Select
 Next i
 .Range("A1:CU" & lr).AutoFilter Field:=3, Criteria1:=arr.keys, 
Operator:=xlFilterValues
End With
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2019-02-07 05:30:56

我相信这就是你要找的:

arr.Item(CStr(.Cells(i, "C").Value2))

票数 2
EN

Stack Overflow用户

发布于 2019-02-07 05:31:11

在将值添加到过滤器字典之前,只需添加一个测试来查看该值是否为数字:

代码语言:javascript
复制
 Select Case UCase(.Cells(i, "C").Value2)
     Case "NA", "ND", "NH", "NK", "NL", "NQ", "NV"
         'do nothing
     Case Else
         If Not IsNumeric(.Cells(i, "C").Value2) Then
            arr.Item(.Cells(i, "C").Value2) = vbNullString
         End If
 End Select
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/54562470

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档