matlab excel 宏,Matlab可以通过ActiveX在Excel文件中编写宏吗?

一旦您允许以编程方式访问VBA项目,我建议您将宏写入文本文件(* .txt或* .bas),然后运行导入此文本文件的命令具有VBA代码模块.例如:

DataFileName = 'D:\Test\DataFile.xlsm';

CodeFileName = 'D:\Test\CodeFile.txt';

Excel = actxserver('Excel.Application');

Workbooks = Excel.Workbooks;

Workbook=Workbooks.Open(DataFileName);

% Make Excel visible (Optional)

Excel.visible = 1;

%% Import the code

Import(Workbook.VBProject.VBComponents,CodeFileName);

%% Save

Excel.Application.DisplayAlerts = 0; %Avoid overwrite warning

SaveAs(Workbook,DataFileName);

Excel.Application.DisplayAlerts = 1;

%% Close Excel

Quit(Excel);

delete(Excel);

在这种情况下,CodeFile.txt可能如下所示:

Attribute VB_Name = "ModuleName"

Option Explicit

Sub SomeMacro()

Msgbox "From MATLAB, with love..."

End Sub

这里,行属性VB_Name = …是必不可少的,将确定模块的名称.对于Option Explicit,它不是强制性的,但它是good practice.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值