VBA set去重中,range对象无法获取row的问题

这段VBA代码旨在通过Dictionary对象去重Range("b4:b37")中的值。当找到重复值时,代码会查找该值在Range中的位置,并删除相应行。但可能存在无法正确获取Row的问题,需要检查Find方法的使用和行删除的操作是否影响了循环过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Sub 选项按钮1_Click()
Dim dict3 As Object
Set dict3 = CreateObject("scripting.dictionary")

Set arr1 = Range("b4:b37")

For Each i In arr1.Value
    If Not dict3.exists(i) Then
       dict3.Add i, ""
       'Debug.Print i
       'I.Offset(0, 1).Value = I.Value
       
    Else
        Debug.Print i
        
        Set rang = ActiveSheet.Range("b4:b37").Find(i)
        Debug.Print rang.Address; rang.Row; rang.Value;
        Rows(rang.Row).Delete
        
        Debug.Print 111111111
        
        Exit Sub
    End If
Next
End Sub
 

地区
河南
重庆
浙江
浙江

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值