LS说KILL进程的朋友们···我说。。。你们真行!!!如果用户是administrator还行,如果不是怎么办??你是没有权限KILL滴!!!
 

object objmissing = System.Reflection.Missing.Value;



Excel.ApplicationClass application = new ApplicationClass();

Excel.Workbook book = application.Workbooks.Add(objmissing);

Excel.Worksheet sheet = (Excel.Worksheet)book.Worksheets.Add(objmissing,objmissing,objmissing,objmissing);



//操作过程 ^&%&×&……&%&&……



//释放

sheet.SaveAs(path,objmissing,objmissing,objmissing,objmissing,objmissing,objmissing,objmissing,objmissing);

System.Runtime.InteropServices.Marshal.ReleaseComObject((object)sheet);

System.Runtime.InteropServices.Marshal.ReleaseComObject((object)book);

application.Quit();

System.Runtime.InteropServices.Marshal.ReleaseComObject((object)application);

System.GC.Collect();

有一点,在网上你是找不到滴···纯属经验:
如果你要写的Excel是多个Sheet的话,那么你最好写个函数:
比如 private bool overdue_report_sub(Excel.Worksheet sheet)
将sheet的对象传进去,在这个函数中进行操作,函数过程只写Sheet的操作过程,释放还是放在外面。如果你不这样做的话,那么,恭喜你,你还是释放不掉。但是如果只有一个Sheet操作的话,你就可以不用写这个函数了,只是在整个函数体中进行创建和释放。