excel中 vba编程错误

想要实现在sheet2中提取出sheet1中的第三列大于0的列可是一直报错一直把我的loopuntil那一句标黄,求大神帮忙解决下这个问题... 想要实现在sheet2中 提取出sheet1中的第三列大于0的列 可是一直报错一直把我的loop until 那一句标黄, 求大神帮忙解决下这个问题 展开
 我来答
天命之城
2018-06-08 · 超过29用户采纳过TA的回答
知道答主
回答量:75
采纳率:71%
帮助的人:9.6万
展开全部
Private Sub Worksheet_selectionchange()
Dim a, b,s As Integer
s = Sheet1.UsedRange.Rows.Count
For a = 1 To s
    If Sheet1.Cells(a, 3) > 0 Then
    b = b + 1
    Sheet2.Cells(b, 1) = Sheet1.Cells(a, 1)
    Sheet2.Cells(b, 2) = Sheet1.Cells(a, 3)
    End If
    Next
End Sub

以上代码可以实现你需要实现的功能,已测试过,放心使用。O(∩_∩)O~

你的代码里面a=a+1,这个循环a没有设置上限,如果一直运行下去会报错。

我在你的a=a+1这个代码下面加了debug.print a 测试了一下,就卡死了。

a会一直循环增大到报错。

linyhuan
2018-06-08 · 超过12用户采纳过TA的回答
知道答主
回答量:78
采纳率:100%
帮助的人:26.9万
展开全部
如果你第三列都没有符合>0,就会出错了,前面加个On Error Resume Next就可以了
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
阳光上的桥
2018-06-08 · 知道合伙人软件行家
阳光上的桥
知道合伙人软件行家
采纳数:21423 获赞数:65813
网盘是个好东东,可以对话和传文件

向TA提问 私信TA
展开全部
这个界面点【调试】看黄色条在哪一行,鼠标放在该行的变量上,看看变量的值是多少
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
毋巧uH
2018-06-08 · TA获得超过279个赞
知道小有建树答主
回答量:267
采纳率:80%
帮助的人:54.9万
展开全部
改成 sheets("sheet1").cells(a,3) 试试
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式