Excel VBA如何创建可撤销操作的宏

方法来自:http://www.exceltip.net/thread-9582-1-1.html,如转载请注明出处。

在VBA宏执行后,一般是不能撤销操作的(快速访问工具栏或者编辑栏里的撤销按钮)。那么当有时候误操作的时候就不得不关闭文档再次开启。其实VBA中提供了我们撤销宏操作的方法,但是这个方法就是我们得编写一个撤销宏操作的另一个宏。虽然比较繁琐,但是这个方法可以让我们将操作之前的数据作为参数传递,从而完整恢复宏操作之前的状态。
在宏的最后我们加上如下语句即可指定进行撤销操作时执行的宏。注意有两个参数

Application.OnUndo 撤销按钮显示的内容,指定宏的名称
请参考例子:

Sub Test1()
    Dim Temp
    Temp = Range("A1")      '记录A1之前的数据
    Range("A1") = 100       '操作A1
    '创建可撤销的操作。并指定带参数的Test2为撤销时的宏
    Application.OnUndo "撤销Test1宏操作", "'Test2 """ & Temp & """'"
End Sub
Sub Test2(ByVal Rng)
    Range("A1") = Rng   'Test2可以用于恢复A1原来的值
End Sub




  • 3
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
Excel VBA 是一种编程语言,可以在Excel创建自定义函数来实现各种功能。通用函数是一种可以被多个工作表或工作簿调用的函数,在不同的数据和条件下都能正常工作。 要创建通用函数,首先需要打开Excel并按下“ALT + F11”来打开Visual Basic for Applications(VBA)编辑器。 在编辑器中,选择插入菜单,并点击“模块”来创建一个新的模块。在模块中,可以编写自己的VBA代码来定义函数。 为了创建通用函数,需要确定函数的名称、输入参数和返回值。可以使用“Function”关键字来定义函数并指定函数的名称。例如,以下是创建一个计算两个数之和的通用函数的示例代码: ``` Function SumNumbers(num1 As Double, num2 As Double) As Double SumNumbers = num1 + num2 End Function ``` 在上述示例中,函数名为`SumNumbers`,它接受两个参数`num1`和`num2`,返回一个值作为两个参数的和。 定义好函数后,可以在Excel工作表中调用它。在单元格中输入`=SumNumbers(2, 3)`,按下回车键即可获取计算结果。 通用函数不仅仅限于简单的计算,还可以实现复杂的逻辑和数据处理。可以在函数内部使用VBA的各种功能来满足实际需求,例如控制流程、条件判断、循环等。 总之,通过Excel VBA,可以轻松创建能在多个工作表或工作簿中使用的通用函数,以实现更高效、精确和自动化的数据处理和计算。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值