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

 채택된 답변

Image Analyst
Image Analyst 2012년 7월 3일
편집: Image Analyst 2012년 7월 3일

0 개 추천

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

Sabbas
Sabbas 2012년 7월 3일
편집: Sabbas 2012년 7월 3일
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 2012년 7월 3일
편집: Sabbas 2012년 7월 3일
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
Geoff
Geoff 2012년 7월 4일
편집: Geoff 2012년 7월 4일
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
Walter Roberson
Walter Roberson 2012년 7월 4일
If you aren't going to put a number into baseFileName, then don't bother with sprintf().
baseFileName = 'input.xlsx';
Sabbas
Sabbas 2012년 7월 4일
thanks Geoff
Sabbas
Sabbas 2012년 7월 4일
편집: Sabbas 2012년 7월 4일
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..
Image Analyst
Image Analyst 2012년 7월 4일
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.

댓글을 달려면 로그인하십시오.

추가 답변 (0개)

카테고리

도움말 센터File Exchange에서 Startup and Shutdown에 대해 자세히 알아보기

태그

Community Treasure Hunt

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

Start Hunting!

Translated by