xlswrite and more efficient coding

Dear all,
I have the following command
xlswrite('data_Aus_Di_out'1.xlsx', yy ,'Sheet1', 'A2')
I would like to have something like
k={'data_Aus_Di_out'}
xlswrite('k.xlsx', mdata1 ,'Sheet1', 'A2')
so as to be able to change the name of the excel file OUTSIDE the lxswrite function
thank you

 Accepted Answer

Image Analyst
Image Analyst on 3 Jul 2012
Edited: Image Analyst on 3 Jul 2012
Use sprintf() to create whatever base filename you want. Use fullfile() to combine the folder and the base filename into the full path (folder plus base filename). Also, see the FAQ: http://matlab.wikia.com/wiki/FAQ#How_can_I_process_a_sequence_of_files.3F for examples of how to create a variety of filenames in different ways.
% Make a base file name that has a number embedded in it.
baseFileName = sprintf('dataoutput_Austria_Diapers_output%d.xlsx', k);
% Combine it with the folder to get the full path of the file.
fullFileName = fullfile(folder, baseFileName);
% Now write it out to an Excel workbook.
xlswrite(fullFileName, mdata1 ,'Sheet1', 'A2');

7 Comments

THanks imager. IT works:
myFolder = 'C:\Users\sabbas\Documents\MATLAB\wers';
baseFileName = sprintf('input.xlsx', 1);
fullFileName = fullfile(myFolder, baseFileName);
[num,txt,raw]=xlsread(fullFileName);
[num,txt,raw]=xlsread(fullFileName);
However, the button at the top right of the editor is red. The problem seems to be in
baseFileName = sprintf('input.xlsx', 1);
because when I point the cursor to the this command, I read that
"Format string apparently does not with the argument count"
Why is this the case. can we fix that?
thanks
Sabbas
Sabbas on 3 Jul 2012
Edited: Sabbas on 3 Jul 2012
I noticed that by eliminating the number from baseFileName, that is by having just
baseFileName = sprintf('input.xlsx');
the problem seems to disappear and the code still works. Is my approach risky?
thanks
I don't think you understand sprintf correctly. It will build a string based on a format and a number of arguments that supply data (referenced by the format). In your case, you have not indicated any additional data in the format string.
baseFileName = sprintf('input.xlsx', 1);
That is a roundabout way of doing this:
baseFileName = 'input.xlsx';
Perhaps you meant this (note the '%d' indicates that you have supplied an integer and its value is to be converted to a string and inserted at that location):
baseFileName = sprintf('input%d.xlsx', 1);
I suggest you read the documentation on sprintf:
doc sprintf
If you aren't going to put a number into baseFileName, then don't bother with sprintf().
baseFileName = 'input.xlsx';
thanks Geoff
Sabbas
Sabbas on 4 Jul 2012
Edited: Sabbas on 4 Jul 2012
I think that the easiest approach is the following
k='output1.xlsx'
xlswrite(k, yy ,'Sheet1', 'A2')
Am I right? In this way I do not need to use "fullfile" etc..
Sure, that's easier, but not as robust. If you know for a fact that you always want to put your workbook in the same folder as your m-file, rather than, say the folder where your input data came from or somewhere else, then you can omit the folder and store it in whatever the current directory is. I recommend you read the FAQ: http://matlab.wikia.com/wiki/FAQ#Where_did_my_file_go.3F_The_risks_of_using_the_cd_function. so you don't specify where the workbook should go via the cd function.

Sign in to comment.

More Answers (0)

Categories

Tags

Community Treasure Hunt

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

Start Hunting!