Error using save: Error closing file

Hey all,
An instance of a class is filled with a lot of data and than saved to my harddisk.
However, during saving, I get the following error: Error using save: Error closing file dummy.mat
I thought it had to do with a lack of memory, but I've monitored the process during saving and I never run out of RAM, and I know that I have plenty of space left on my harddisk.
Does anyone know what causes this error?
Any suggestions are much appreciated!

1 commentaire

Rafael Lopez Campos
Rafael Lopez Campos le 17 Déc 2020
Hi, I had the same problem. I was working my script in a external device, so I fixed it moving my environment in the same device Matlab is installed.

Connectez-vous pour commenter.

 Réponse acceptée

Jared
Jared le 18 Oct 2011

20 votes

Hi Bert,
I ran into the same error message a day or two ago with a struct filled with instances of classes that were similarly filled with lots of data. However, I could see in task manager that the memory use was in fact spiking.
The problem went away when I switched to version 7.3 format from version 7 (change file->preferences->general->MAT-Files or I think add flag '-v7.3' to save). This led me to believe that the memory problems might have had something to do with the form of compression done in mat files in version 7.
However, this does not solve another problem associated with save and load which might also cause some issues (it does for me). MATLAB uses lazy copying to conserve memory, i.e. A = B does not make a new copy of B until some part of A is later changed, e.g. perhaps A(end) = 1. Mat files appear to forget about all of these memory-saving relations, increasing both the size of the save files as well as the space required in memory once the save file is loaded.
Hope this helps! Jared

16 commentaires

Bert
Bert le 18 Oct 2011
Hey Jared,
Indeed this turned out to be the problem. I figured this out a while ago but forgot to report it to the community.
I think it would be a valuable addition in the error message as a suggestion ('Maybe add -v7.3?'), because the user is pretty much left in the dark about the reasons of this error message.
Jesse Salazar
Jesse Salazar le 17 Jan 2015
Also worked for me. No issues thus far with the lazy copying. Bert, do you anticipate issues with data integrity? Or simply with redundancy/memory? For my purposes, as long as there is no issue with data integrity, I should be okay. Thanks for your post,
-J
Colin
Colin le 27 Jan 2016
Great answer. I would have lost days without it! Thanks!
Céldor
Céldor le 4 Oct 2016
Thanks for this answer. I had the same error and adding '-v7.3' solved the problem. Before, I though the problem would be somewhere else as it suggests network or HDD problems.
I also believe adding more explanatory error would save everybody's time.
Scott Tuttle
Scott Tuttle le 11 Juil 2017
Many Thanks Jared! Using '-v7.3' on the save command fixed my case. I now made 7.3 the default in my preferences.
Rosalyn Putland
Rosalyn Putland le 17 Jan 2018
Thanks this fix worked perfectly!
Hans Kramer
Hans Kramer le 18 Sep 2018
Thanks man. Worked for me as well.
Manuel Lera Ramírez
Manuel Lera Ramírez le 4 Déc 2019
Hello Jared,
Thank you so much for your response. Allowed me to save some data it had taken me a while to analyse.
Mingli ZHU
Mingli ZHU le 23 Avr 2021
Tnanks, that helps
dain Yoon
dain Yoon le 29 Juil 2021
Thanks, that helps !!
Neil Arnold
Neil Arnold le 12 Août 2021
Caveat emptor! I have generated a similar problem when trying to append to an existing file using the '-struct' option. In this case the '-v7.3' solution doesn't work. Moreover when I've attempted to load the existing data into memory, add the new data to the structure and save in v7.3 the process still fails. I have no working solution. I've resorted to the brute force solution of saving separate files (as v7 BTW)..
Tiago Ávila
Tiago Ávila le 10 Déc 2021
This also works on Ubuntu 21.04 with big files! Was hoping the command window would hint at this since it's a common issue.
Berkin Birol
Berkin Birol le 28 Jan 2022
Modifié(e) : Berkin Birol le 28 Jan 2022
Thank you Jared for the answer, it saved me from a lot of work.
And thank you Bert for asking the question :)
baby
baby le 19 Août 2022
Modifié(e) : baby le 19 Août 2022
Thanks a bunch. Solved my problem too by -v7.3. Spent days to take tries with different options for nothing.
Alejandro
Alejandro le 13 Fév 2023
Thanks a lot! This was extremely useful! Solved the same problem by using this method!
Ankit Nag
Ankit Nag le 22 Juin 2023
Is there any way to use -v7.3 and yet keep the file size reasonable. I am saving figures plotted from a large data set and faced this issue. I was able to solve it using v7.3 but I am trying to keep them at a manageable file size. Using -v7.3 seems to be doubling the figure's file size.

Connectez-vous pour commenter.

Plus de réponses (2)

Jonathan Pelham
Jonathan Pelham le 17 Fév 2015

0 votes

I have had a similar error message. This is a very old q&a. Does anyone know if the answer is still valid?

1 commentaire

Ingo Schalk-Schupp
Ingo Schalk-Schupp le 21 Juil 2015
For me, this also did the trick. I was saving using the -v6 switch, and I got the error reproducibly. After I removed it, the error did not occur any longer.

Connectez-vous pour commenter.

Zaki Mohzani
Zaki Mohzani le 7 Sep 2016

0 votes

Ran into this error today. That error message should be updated to reflect the new 'v7.3' option.

3 commentaires

Henrique Costa
Henrique Costa le 5 Mai 2017
Now it is: save('myFile.mat','-v7.3','-nocompression');
Henrique Costa
Henrique Costa le 5 Mai 2017
or, if you want compression : save('myFile.mat','-v7.3');
Adam Bruce
Adam Bruce le 18 Nov 2020
Modifié(e) : Adam Bruce le 18 Nov 2020
This still works on 2020a. Thanks!

Connectez-vous pour commenter.

Catégories

En savoir plus sur Historical Contests dans Centre d'aide et File Exchange

Produits

Community Treasure Hunt

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

Start Hunting!

Translated by