有一段VBA代码,有A、B两列,求B列数据在A列中第一个相同数据的行号并填入C列对应B列的行中,代码如下:

Sub查找()DimI,J,rA,rBAsLongrA=Cells(65536,1).End(xlUp).RowrB=Cells(65536,2).End(xlUp).R... Sub 查找()
Dim I, J, rA, rB As Long
rA = Cells(65536, 1).End(xlUp).Row
rB = Cells(65536, 2).End(xlUp).Row
For I = 1 To rB
For J = 1 To rA
If Cells(I, 2) = Cells(J, 1) Then
Cells(I, 3) = J
J = rA
End If
Next J
Next I
End Sub
以上代码测试无误,由于行数太多,循环运算太慢,请帮忙改一下,定义一个变量存储运算结果,然后一次性填入C列中如何。
展开
 我来答
Zipall
2012-02-14 · TA获得超过1.3万个赞
知道大有可为答主
回答量:8104
采纳率:42%
帮助的人:8484万
展开全部
我觉得是你循环嵌套的缘故.
试试这样

Sub 查找()
Dim i, a, b, rb As Long
rb = Cells(65536, 2).End(xlUp).Row
ReDim a(1 To rb, 1 To 1)
For i = 1 To rb
Set b = Range("a:a").Find(Cells(i, 2), Range("a65536"), , xlWhole)
If Not b Is Nothing Then a(i, 1) = b.Row
Next
Cells(1, 3).Resize(rb, 1) = a
End Sub
一起提升高效办公
2012-02-14 · TA获得超过1010个赞
知道小有建树答主
回答量:747
采纳率:0%
帮助的人:826万
展开全部
用数组进行循环处理,速度会大幅度提高!

Sub 查找()
Dim I, J, rA, rB, rC
rA = Range("A1:A" & Range("A65536").End(xlUp).Row)
rB = Range("B1:B" & Range("B65536").End(xlUp).Row)
If UBound(rA) > UBound(rB) Then
ReDim rC(1 To UBound(rA))
Else
ReDim rC(1 To UBound(rB))
End If

For I = 1 To UBound(rB)
For J = 1 To UBound(rA)
If rA(J, 1) = rB(I, 1) Then rC(I) = J: Exit For
Next J
Next I
Range("C1").Resize(UBound(rC)) = WorksheetFunction.Transpose(rC)
End Sub
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
wsygdhr119
2012-02-14 · TA获得超过2109个赞
知道大有可为答主
回答量:2432
采纳率:0%
帮助的人:2119万
展开全部
For I = 1 To rB
For J = 1 To rA
If Cells(I, 2) = Cells(J, 1) Then
Cells(I, 3) = J
J = rA
exit for '找到后就退出j循环,不需要完成整个循环,继续下一个i。加上这句最简单。
End If
Next J
Next I
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
o自在o
2012-02-14 · TA获得超过1377个赞
知道小有建树答主
回答量:1418
采纳率:62%
帮助的人:824万
展开全部
不用宏的解决办法:
在C1输入公式
=IF(ISERROR(MATCH(A1,B:B,0)),"",MATCH(A1,B:B,0))
向下复制公式。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式