0

我正在使用 Excel 2010 并向电子表格添加一个小的 VBA 宏。(宏的目的是获取活动工作表上的数据并将其导出到 CSV 文件,但这与问题无关。)宏确定使用ThisWorkbook.Path. 我还在快速访问工具栏中添加了一个自定义按钮来激活宏。

在我的实验电子表格(Test.xlsm,存储在一个路径中)中获得工作算法后,我在另一个路径中制作了电子表格的副本并将其重命名为_Database.xlsm。然后我打开 _Database.xlsm 并运行宏。令我惊讶的是,该文件被写入原始路径,而不是新路径。低头看 Windows 工具栏,我看到 Excel 也以原始路径打开了原始文件。

经过大量的代码调整、检查属性等,我终于发现我可以通过打开复制的电子表格、删除快速访问工具栏按钮、重新添加它,然后保存文件来防止这种情况发生。我的问题是:

  1. 为什么宏不能与电子表格一起“独立移植”?即为什么副本与原始表格保持这种联系?

  2. 有没有一种方法可以创建或修改宏以使其在这种意义上具有可移植性?

4

1 回答 1

1

如果您希望工具栏/按钮与文件一起旅行(即不总是链接回原始版本),那么您需要将其添加到文件本身,而不是 QAT。QAT 仅“知道”您将按钮链接到的实际文件。

最好将宏添加到您的个人宏工作簿,然后让它在 ActiveWorkbook 上运行。

但是,如果您想将其分发给其他用户,您可以将宏保留在“数据库”工作簿中并添加自定义功能区部件。见:http ://www.rondebruin.nl/win/s2/win001.htm

于 2013-07-24T04:25:26.860 回答