AutoFilter数组在使用更多元素时无效 VBA
创始人
2024-11-12 13:30:09
0

问题描述:当使用AutoFilter方法对数组进行筛选时,发现在数组中包含更多元素时,筛选结果无效。

解决方法:

  1. 使用AdvancedFilter方法:AdvancedFilter方法比AutoFilter方法更适用于处理大量数据。它可以直接在数组中执行筛选操作。
Sub AdvancedFilterArray()
    Dim dataArr As Variant
    Dim resultArr() As Variant
    Dim criteriaRange As Range
    Dim filterRange As Range
    
    ' 获取数据数组
    dataArr = Range("A1:A10").Value
    
    ' 设置筛选条件
    Set criteriaRange = Range("B1:B2")
    
    ' 设置筛选范围
    Set filterRange = Range("A1:A10")
    
    ' 执行筛选
    filterRange.AdvancedFilter Action:=xlFilterInPlace, CriteriaRange:=criteriaRange
    
    ' 将筛选结果赋值给结果数组
    resultArr = filterRange.SpecialCells(xlCellTypeVisible).Value
    
    ' 显示结果
    Range("D1").Resize(UBound(resultArr)).Value = resultArr
End Sub
  1. 使用Excel工作表进行筛选:将数组中的数据复制到Excel工作表中,然后使用Excel的筛选功能进行筛选操作。
Sub FilterUsingWorksheet()
    Dim dataArr As Variant
    Dim resultArr() As Variant
    Dim ws As Worksheet
    Dim filterRange As Range
    
    ' 获取数据数组
    dataArr = Range("A1:A10").Value
    
    ' 创建新的工作表
    Set ws = Worksheets.Add
    
    ' 将数据数组复制到工作表中
    ws.Range("A1").Resize(UBound(dataArr)).Value = dataArr
    
    ' 设置筛选范围
    Set filterRange = ws.Range("A1:A10")
    
    ' 执行筛选
    filterRange.AutoFilter Field:=1, Criteria1:="Criteria"
    
    ' 将筛选结果赋值给结果数组
    resultArr = filterRange.SpecialCells(xlCellTypeVisible).Value
    
    ' 显示结果
    Range("D1").Resize(UBound(resultArr)).Value = resultArr
    
    ' 删除工作表
    Application.DisplayAlerts = False
    ws.Delete
    Application.DisplayAlerts = True
End Sub

这两种方法可以在处理大量数据时有效地进行筛选操作。您可以根据具体情况选择适合您的方法。

相关内容

热门资讯

透视窍门!hhpoker辅助软... 透视窍门!hhpoker辅助软件,HHpoker有透视都是有开挂,4分钟教程(有挂教学)1、hhpo...
透视机巧!pokemomo辅助... 透视机巧!pokemomo辅助工具,WePoKer轻量版确实存在有下载,第七分钟教程(有挂神器)一、...
透视积累!aapoker辅助插... 透视积累!aapoker辅助插件工具,AApoker免费切实有辅助,6分钟教程(有挂规律)1)aap...
透视步骤!hhpoker到底可... 透视步骤!hhpoker到底可以作必弊码,HHpoker控制好像是真的有开挂,五分钟教程(有挂规律)...
透视要领!wpk控制牌是真的吗... 透视要领!wpk控制牌是真的吗,WPK辅助一直存在有透视,第六分钟教程(有挂方针)亲,关键说明,wp...
透视指南书!aapoker如何... 透视指南书!aapoker如何设置胜率,AApoker安装包真是有安装,第五分钟教程(的确有挂)aa...
透视指南!模拟器打开hhpok... 透视指南!模拟器打开hhpoker,HHpoker机器人切实存在有下载,三分钟教程(有挂详细)1、全...
透视项目!德州圈脚本,德普之星... 透视项目!德州圈脚本,德普之星透视切实是真的有开挂,6分钟教程(真是有挂)进入游戏-大厅左侧-新手福...
透视模块!德州透视插件,WPK... 透视模块!德州透视插件,WPK链接一直有插件,第九分钟教程(有挂详细)1、首先打开德州透视插件辅助器...
透视操作!epoker透视底牌... 透视操作!epoker透视底牌,HHpoker德州局本来存在有插件,四分钟教程(有挂细节);该软件可...