[Matlab App Designer] 导出UITable中数据至Excel

如果UITable中数据格式为cell,则使用 writecell 将UITable中数据写入Excle
同理,若数据格式为 table, 则使用writetable
writetable函数使用格式参考Matlab官方文档(writecell是类似的):
https://ww2.mathworks.cn/help/matlab/ref/writetable.html?searchHighlight=writetable&s_tid=srchtitle
官方文档中还介绍了导出至.txt格式文件的用法
这里给出.xls格式用法介绍:

writetable(app.UITable.Data,'myData.xls','Sheet',1,'Range','B2:F6')

其中,app.UITable.Data为UITable中的数据,
以上仅仅为将表中数据写入Excle表格

因为界面开发需要,我还要实现 通过点击“导出”按钮,弹出将文件保存至指定位置的窗口
(通过参考资料:https://blog.csdn.net/Surefrp/article/details/109047142)
最终在我的程序中实现方式如下:
首先弹出保存文件的窗口,然后实现数据写入Excle功能。

            [filename_out, pathname, FileIndex] = uiputfile('xxx表.xls','文件保存为');
             if FileIndex == 0  % 如果选择了cancel    
 	          return;
             else
                excle_name = app.UITable_Plantime.ColumnName;    						% 提取UITable表头
                writecell(excle_name', filename_out,'Sheet',1,"Range",'A1:D1');        % 将表头置于Excle第一行
                writecell(app.UITable_Plantime.Data, filename_out,'Sheet',1,'Range','A2:D37')
            end

上面的代码是有缺陷的,因为暂时不知道怎么将UITable的表头一并写入Excle,因此分了两次读入,这样做的缺陷就是需要指定数据存入Excel表中的位置范围。
目前我自己的解决思路是将两个cell合并为一个cell,那在读入的时候则不需要指定‘Range’,尝试了简单粗暴的用{}将两个cell数据组合,但合成的大cell包括两个cell文件,writecell无法处理。这个后续有时间再尝试吧,如果有更简便的方法,也希望可以指出。

一个实现效果
[Matlab App Designer] 导出UITable中数据至Excel_第1张图片

你可能感兴趣的:(MATLAB,App,Designer,matlab)