首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >输出excel图表为图片(通过自动化)

输出excel图表为图片(通过自动化)
EN

Stack Overflow用户
提问于 2015-09-09 09:58:02
回答 1查看 1.2K关注 0票数 3

我试图得到一个处理excel图形,并保存它通过MATLAB。

到目前为止,我已经设法遍历了工作表,并获得了图形对象的句柄,但是我无法保存它。

有人知道如何将对象导出为jpgpng或其他图形格式吗?

我使用SaveAs方法尝试了下面的代码,但是它不起作用

代码语言:javascript
复制
Workbook = Workbooks.Open(['file.name]);
Sheets = Workbook.Sheets;
for i = 1:Sheets.Count
    Activesheet = get(Sheets, 'Item',i);
    for j = 1:Activesheet.ChartObjects.Count
        obj = Activesheet.ChartObjects(j);
        obj.SaveAs('asfasfa.jpg')

    end
end
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-09-09 11:21:56

excel Chart对象具有Export方法。

微软文档:Chart.Export方法(Excel)

例如,我在第一个工作表中创建了一个简单的excel文件(名为test_save_chart.xlsx)。要将此图表导出为PNG图片非常简单:

代码语言:javascript
复制
xfile = 'test_save_chart.xlsx' ;
exl = actxserver('excel.application');                  %// Create a COM server
exlFile    = exl.Workbooks.Open( [pwd '\' xfile] );     %'// Open the file

chartobj = exlFile.Sheets.Item('Sheet1').ChartObjects(1) ;                %// get a handle to the chart object
chartobj.Chart.Export('C:\TEMP\StackExchange\testChartExport.png','PNG')  %// export to PNG

在您的例子中,在您的循环中,它非常简单:

代码语言:javascript
复制
chartobj = Activesheet.ChartObjects(j) ;
chartobj.Chart.Export('your_filename_here.png','PNG')

因为您是在循环中这样做的,所以您必须动态地生成文件名(否则您将一次又一次地覆盖同一个文件)。

请注意,png格式比jpg推荐,特别是对于“线条艺术”风格的图片,如excel图表制作。

票数 5
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/32476474

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档