Save matrix as a spreadsheet image

I am trying to programatically save a matrix as a .jpg or .png file. The output should be a jpg that looks like a spreadsheet, similar to an excel document. For example, if the matrix was:
1 2 3
4 5 6
7 8 9
The output of the program should look something like this (screenshot from excel) in a jpg or png file:
What function should I use to make this happen?
Thank you!

 Accepted Answer

Adam Danz
Adam Danz on 13 Jul 2022
Edited: Adam Danz on 13 Jul 2022
Storing numeric data in images makes it difficult to work with those data later on but I remember a use-case for this back when I wanted to quickly snap-shot small data sets for visual reference (still not sure it was the best approach).
Nevertheless, if your matrix fits on a single page, you could put the data in a uitable and then extract the figure using exportapp. Note that precision may be lost since there is a finite number of decimal places that will appear on the table. See uitable documentation to learn how to apply column and row labels.
x = rand(10,5)*100;
fig = uifigure(); % must be uifigure
uit = uitable(fig,'Units','Normalize','Position',[0 0 1 1],'Data', x)
After the figure and uitable are rendered, you can export the figure as an image using exportapp.
% drawnow % only needed if calling exportapp immediately after uitable.
% pause(.5) % only needed if calling exportapp immediately after uitable.
exportapp(fig, 'mytable.png')

7 Comments

The table generation is fine, but when I open the image up, it is blank. What can I do to fix this? Thanks!
Are you using uifigure() and not regular figure()?
Are you supplying the figure handles to uitable (uitable(fig,...))?
Are you using exportapp rather than exportgraphics?
I see you're using R2020b (thanks for filling out the release info). I just tested it in 2020b and it exports the table as a png as expected.
Yes, I just copied the code that you gave. Not sure why it's not working.
I see what's happening and was able to reproduce the problem.
The figure and uitable need to be rendered before exporting the image. If you run the entire code at once, exportapp is called too quickly before the uitable is rendered.
I'll update my answer to include the following two lines that will prevent this problem.
Place these lines before exportapp
drawnow
pause(.5)
drawnow alone did not solve the problem, the additional pause is necessary but the duration of the pause might be reducible.
This is great. Thank you very much! I'll accept this answer now.
Sorry, another issue just arose. What do I do if my matrix does not fit on one page? Can I resize it?
Thanks!
What is your matrix size?

Sign in to comment.

More Answers (0)

Categories

Find more on Environment and Settings in Help Center and File Exchange

Products

Release

R2020b

Asked:

on 13 Jul 2022

Commented:

on 13 Jul 2022

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!