怎么用EXCEL VBA实现符合条件的复制工作表

请教各位老师,在下刚刚VBA入门我想要实现的功能是,通过对“选择”工作表内的数据进行判断,符合条件的复制对应的工作表到新建工作簿里,最终筛选形成1个包含所有符合条件工作表... 请教各位老师,在下刚刚VBA入门
我想要实现的功能是,通过对“选择”工作表内的数据进行判断,符合条件的复制对应的工作表到新建工作簿里,最终筛选形成1个包含所有符合条件工作表的excel工作簿。

我用的是if,我的思路是罗列出所有符合的条件,方法有点笨,语句是这样的
sub 筛选工作表()
If Sheets("选择").Range("A1").Value = 1 Then
Sheets("1").Copy
ElseIf Sheets("选择").Range("A2").Value = 1 Then
Sheets("2").Copy
......
End If
End sub

运行的结果,只复制出第一个符合条件的工作表。
无法实现一次性复制出所有符合条件的工作表,并且让所有工作表在同一个工作簿中

因此向各位老师求教!十分感谢!
“选择”工作表中的内容:
A B
1 1 1
2 1 2
3 1 3
4 1 4

还有工作表“1”、“2”、“3”、“4”
目的:A列为判断,B列为表页名称,为1则复制输出对应名称的表页,根据各位的前辈的意见,已将语句改为以下所示
症状:复制出第一个判断有效的表页后,提示“下标错误”,我猜测是使用copy的方法不正确,请各位前辈给予修正的建议

Sub 筛选工作表()
Dim i As Integer
Dim s As String

For i = 1 To 4
If Sheets("选择").Range("A" & i).Value = 1 Then
s = Sheets("选择").Range("B" & i).Value
Sheets(s).Copy

End If
Next i
End Sub
展开
 我来答
太极健1969
2014-03-28 · TA获得超过9034个赞
知道大有可为答主
回答量:8668
采纳率:69%
帮助的人:3625万
展开全部
使用了if,就是满足了第一个条件后,就不再继续判断其他,当然只有一个了。你应该用循环去进行判断
看你的代码你似乎是想根据选择这个表的A列是否为1来判断第几个工作表被复制到新工作簿中,是这样吗?
更多追问追答
追问
是的,凡是A列为1所对应的工作表,都复制出来
追答
你的新工作簿是指定的,还是新建的?
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
tianqixueyu
2014-03-28 · TA获得超过2700个赞
知道大有可为答主
回答量:1350
采纳率:80%
帮助的人:457万
展开全部
用个循环套一下:
sub 筛选工作表()
For i = 1 to 100
If Sheets("选择").Range("A" & i).Value = 1 Then
Sheets(i).Copy(目标区域)
End If
next i
End sub
如果你的表名不是1、2、3……那么先将表名建成数组然后再用FOR来循环。
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
gdqgdq
2014-03-28 · 超过45用户采纳过TA的回答
知道小有建树答主
回答量:131
采纳率:50%
帮助的人:49.3万
展开全部
我觉得你程序中逻辑错误。
elseif有问题,非此即彼,导致只复制出一个工作表。
建议在循环语句中,复制一个后马上粘贴一个,再复制下一个,粘贴下一个……
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式