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

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

相关内容

热门资讯

透视科普"wpk系统... 透视科普"wpk系统是否存在作必弊行为"真是真的是有辅助插件(哔哩哔哩)1、任何wpk系统是否存在作...
透视辅助"佛手在线大... 透视辅助"佛手在线大菠萝为什么都输"总是有辅助插件(哔哩哔哩)1、金币登录送、破产送、升级送、活动送...
透视解谜"wpk是真... 透视解谜"wpk是真的还是假的"果然有辅助器(哔哩哔哩)1、不需要AI权限,帮助你快速的进行wpk是...
透视推荐"wepok... 透视推荐"wepoker开脚本视频"一贯有辅助脚本(哔哩哔哩)1、下载好wepoker开脚本视频透视...
透视曝光"wepok... 透视曝光"wepoker私人局俱乐部"都是是有辅助教程(哔哩哔哩)1、下载好wepoker私人局俱乐...
透视辅助"wepok... 透视辅助"wepoker有人用过吗"其实是有辅助神器(哔哩哔哩)1、上手简单,内置详细流程视频教学,...
透视推荐"we po... 透视推荐"we poker辅助器v3.3"总是有辅助软件(哔哩哔哩)1、下载好we poker辅助器...
透视有挂"we-po... 透视有挂"we-poker是什么软件"果然有辅助方法(哔哩哔哩)1、we-poker是什么软件透视辅...
透视详细"poker... 透视详细"poker world辅助器"原来有辅助攻略(哔哩哔哩)1、游戏颠覆性的策略玩法,独创攻略...
透视分享"aapok... 透视分享"aapoker怎么拿好牌"总是有辅助神器(哔哩哔哩)1、每一步都需要思考,不同水平的挑战a...