[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无法处理。这个后续有时间再尝试吧,如果有更简便的方法,也希望可以指出。

一个实现效果
在这里插入图片描述

  • 5
    点赞
  • 39
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值