区域复制的VBA代码

 Sub test()
Dim Rng1 As Range, Rng2 As Range, N%, I%
On Error GoTo ask '设定出错时的跳转位置
retry:
Set Rng1 = Application.InputBox("请用鼠标选择要复制的区域:", , , , , , , 8) '输入要复制的区域,用inputbox方法取得单元格区域范围
Set Rng2 = Application.InputBox("请用鼠标选择目标区第一个单元格位置:", , , , , , , 8) '输入目标区域第一个单元格的位置
N = InputBox("请输入要复制的份数:") '输入次数
For I = 1 To N '循环复制指定区域到新区域,并下移完成指定次数的复制
? ? Rng2(1, 1).Offset((I - 1) * Rng1.Rows.Count, 0).Resize(Rng1.Rows.Count, Rng1.Columns.Count) = Rng1.Value
Next I
Exit Sub '正常操作完成后的退出位置
ask:
ask = MsgBox("输入有误,“是”重试,“否”退出?", vbYesNo, "选择") '出错时提问
If ask = vbYes Then GoTo retry '如果回答重试,则跳到Retry处
End Sub
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值