libérons-vous toutes vos références? (Ce qui signifie que vous devez les enregistrer en premier lieu).
Par exemple, voici ce qui est dans mon Éliminez de certains excel interop():
public void Dispose()
{
if(!this.disposed)
{
if(cell != null)
Marshal.FinalReleaseComObject(cell);
if(cells != null)
Marshal.FinalReleaseComObject(cells);
if(worksheet != null)
Marshal.FinalReleaseComObject(worksheet);
if(worksheets != null)
Marshal.FinalReleaseComObject(worksheets);
if (workbook != null)
{
workbook.Close(false, Type.Missing, Type.Missing);
Marshal.FinalReleaseComObject(workbook);
}
Marshal.FinalReleaseComObject(workbooks);
xlApp.Quit();
Marshal.FinalReleaseComObject(xlApp);
GC.Collect();
GC.WaitForPendingFinalizers();
disposed = true;
}
}
(! Je ne sais pas si cela est parfait, mais il a fonctionné pour moi)
Mes objets ont été scopés localement, donc je mets ça dans un enfin, mais ça marche, merci! –
Contente d'être utile –