【VBA研究】工作表自动筛选模式检测

本文介绍了如何使用VBA检测Excel工作表是否处于自动筛选模式,并提供了解决因自动筛选导致数据处理错误的方法。通过检查ActiveSheet.AutoFilterMode属性,可以判断并移除筛选。若要添加筛选,应确保先定位到字段标题,然后使用类似表达式进行操作。
摘要由CSDN通过智能技术生成

作者:iamlaosong

用VBA程序处理Excel数据文件,用户的数据文件有时处于自动筛选模式,往往导致数据处理不正确,为此,需要检测工作表是否处于该模式,如果是,则去掉自动筛选,语句如下:

        If ActiveSheet.AutoFilterMode = True Then Selection.AutoFilter

这个语句一般只用于去掉自动筛选,虽然Selection.AutoFilter也可以加上自动筛选,但筛选位置却可能在当前单元格处,所以要注意,加自动筛选前,现将单元格定位到字段标题处,然后用如下语句:

        If ActiveSheet.AutoFilterMode = False Then Selection.AutoFilter


如果检测其它非活跃的工作表,可以用下面语句:

If Worksheets("sheet1").AutoFilterMode = True Then 

Worksheets("sheet1").Range("A1").AutoFilter 


附:
Range.AutoFilter Method
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值