XLSWRITE - into same folder location as M file

3 visualizaciones (últimos 30 días)
Vineet Guru
Vineet Guru el 6 de Jun. de 2013
I want to store my M files on a USB stick for protability. Some of these M files create xlsx files as an output. I would like to store these in the same folder location as the M file which creates them. I used the usual xlswrite ('filename.xlsx', variable); but get an error:
Error using xlswrite (line 220)
Invoke Error, Dispatch Exception:
Source: Microsoft Excel Description: Microsoft Excel cannot access the file 'C:\WINDOWS\system32\38C41000'. There are several possible reasons:
• The file name or path does not exist.
• The file is being used by another program.
• The workbook you are trying to save has the same name as a currently open workbook.
Many thanks.

Respuesta aceptada

Vineet Guru
Vineet Guru el 6 de Jun. de 2013
Thanks guys for your attempts. Your help is most appreciated.
I eventually stumbled upon the "uigetfile" instruction as with just a one click on the m file of interest in a folder, and the uigetfile picks up the folder + filename. I then stripped the filename and retained the folder.
  2 comentarios
Walter Roberson
Walter Roberson el 6 de Jun. de 2013
If you just want the directory, then uigetdir() would be more appropriate.
Iain
Iain el 6 de Jun. de 2013
If you know the name of the files, you could use "which" to do it automatically as well.

Iniciar sesión para comentar.

Más respuestas (2)

Azzi Abdelmalek
Azzi Abdelmalek el 6 de Jun. de 2013
You should specify the folder when using xlswrite
xlswrite('yourolder/yourfile.xls',data)
  4 comentarios
Vineet Guru
Vineet Guru el 6 de Jun. de 2013
The pwd instruction points to C:\windows\system32, which is not where my M file is.
Azzi Abdelmalek
Azzi Abdelmalek el 6 de Jun. de 2013
Editada: Azzi Abdelmalek el 6 de Jun. de 2013
How are you running your m-file? your m-files, are not in the current folder? And I am not getting what the aim of what you are looking for

Iniciar sesión para comentar.


Iain
Iain el 6 de Jun. de 2013
Editada: Iain el 6 de Jun. de 2013
[p f] = fileparts(mfilename('fullpath'));
xlswrite([p '\excel filename.xls'], ...)
  3 comentarios
Iain
Iain el 6 de Jun. de 2013
mfilename('fullpath') grabs the path, and the filename of the m file (but not the .m bit)
Jan
Jan el 6 de Jun. de 2013
Editada: Image Analyst el 6 de Jun. de 2013
fullfile(p, 'excel filename.xlsx') considers potentially existing trailing and OS depending file separators automatically.

Iniciar sesión para comentar.

Categorías

Más información sobre Environment and Settings en Help Center y File Exchange.

Etiquetas

Community Treasure Hunt

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

Start Hunting!

Translated by