2

使用 MATLAB,我可以启动 COM 服务器并以编程方式写入 Excel 工作簿。但是,我想不出添加迷你图的方法(建议):

% Open new workbook
excel         = actxserver('excel.application');
excel.visible = 1;
wrkbook       = excel.Workbooks.Add();
sheet         = wrkbook.Sheets.Item(1);

% Write some data
sheet.Range('B1:Z1').Value = rand(1,25);

这是问题所在:

% Add column sparklines to 'A1', type 'xlSparkColumn' and DataSource: 'B1:Z1'
sheet.Range('A1').SparklineGroups.Add('xlSparkColumn','B1:Z1')

我收到以下错误:

Error using Interface.Microsoft_Excel_15.0_Object_Library.SparklineGroups/Add
Error: Object returned error code: 0x800A03EC     

关闭/清理

% Close without saving
wrkbook.Saved = 1;
wrkbook.Close
excel.Quit
delete(excel)

对SparklineGroup 对象 (Excel)的引用。我在 win7 64bit、R2013a 和 Excel 2013 上。

4

1 回答 1

3

尝试:

xlSparkColumn = 2;
sheet.Range('A1').SparklineGroups.Add(xlSparkColumn,'B1:Z1')

将来,如果您想找出某个常量/枚举的对应值,请使用这些 帖子中所示的 IL DASM 工具。

异想天开


编辑

好的,事实证明枚举xlSparkColumn不是这里真正的问题,您可以将其指定为字符串参数,也可以传递枚举的底层整数值。

正如您在评论中提到的问题是您设置了 R1C1参考样式而不是默认的 A1 参考样式,因此您的调用中指定的范围在该格式中无效。

这些中的任何一个都可以工作:

excel.ReferenceStyle = 'xlR1C1';
sheet.Range('A1').SparklineGroups.Add('xlSparkColumn','R1C2:R1C26')

excel.ReferenceStyle = 'xlA1';
sheet.Range('A2').SparklineGroups.Add('xlSparkColumn','B1:Z1')
于 2013-08-01T15:04:14.030 回答