Comment libérer correctement les objets COM Excel interop en C# pour éviter que des processus Excel restent en mémoire ?
La clé est de libérer CHAQUE objet COM que vous créez, dans l’ordre inverse de création :
// Libérer dans l'ordre inverse
Marshal.ReleaseComObject(range);
Marshal.ReleaseComObject(worksheet);
workbook.Close(false);
Marshal.ReleaseComObject(workbook);
excelApp.Quit();
Marshal.ReleaseComObject(excelApp);
// Forcer le ramasse-miettes
GC.Collect();
GC.WaitForPendingFinalizers();
Règle importante : n’utilisez jamais deux points dans un seul appel COM (par exemple excelApp.Workbooks.Open(...) crée un objet Workbooks implicite que vous ne pouvez pas libérer).