真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

ASP.NET中怎么調(diào)用Excel進(jìn)程

ASP.NET中怎么調(diào)用Excel進(jìn)程,很多新手對此不是很清楚,為了幫助大家解決這個(gè)難題,下面小編將為大家詳細(xì)講解,有這方面需求的人可以來學(xué)習(xí)下,希望你能有所收獲。

我們提供的服務(wù)有:成都網(wǎng)站設(shè)計(jì)、網(wǎng)站制作、微信公眾號開發(fā)、網(wǎng)站優(yōu)化、網(wǎng)站認(rèn)證、類烏齊ssl等。為1000多家企事業(yè)單位解決了網(wǎng)站和推廣的問題。提供周到的售前咨詢和貼心的售后服務(wù),是有科學(xué)管理、有技術(shù)的類烏齊網(wǎng)站制作公司

ASP.NET調(diào)用Excel進(jìn)程

關(guān)于在ASP.NET調(diào)用Excel進(jìn)程不能結(jié)束進(jìn)程的問題,常見的解決方法用的是下面這段代碼

wb.Close(null,null,null);  app.Workbooks.Close();  app.Quit();   if(rng!=null)  {  System.Runtime.InteropServices.Marshal.ReleaseComObject(rng);  rng=null;  }  if(ws!=null)  {  System.Runtime.InteropServices.Marshal.ReleaseComObject(ws);  ws=null;  }  if(wb!=null)  {System.Runtime.InteropServices.Marshal.ReleaseComObject(wb);  wb=null;  }  if(app!=null)  {System.Runtime.InteropServices.Marshal.ReleaseComObject(app);  app=null;  }  GC.Collect();

雖然這段代碼在配置正確的情況下能自動(dòng)結(jié)束Excel進(jìn)程,但是前提是在操作Excel時(shí)沒有引發(fā)異常的情況下,如果有異常發(fā)生,那么Excel進(jìn)程將不能結(jié)束(比如:引用了一個(gè)在Excel文件中不存在的文本框時(shí)就會(huì)出現(xiàn)“HRESULT 中的異常:0x800A03EC?!保@時(shí)就要借助Process類的Kill()方法來結(jié)束,下面是我寫的測試代碼:

  1. usingSystem;  

  2. usingSystem.Diagnostics;  

  3. usingexcel=Microsoft.Office.Interop.Excel;  

  4.  

  5. namespaceExcelTest  

  6. {  

  7. /**////

     

  8. ///Excel的摘要說明。  

  9. /// 

  10. publicclassExcel  

  11. {  

  12. privateDateTimebeforeTime;//Excel啟動(dòng)之前時(shí)間  

  13. privateDateTimeafterTime;//Excel啟動(dòng)之后時(shí)間  

  14.  

  15. excel.Applicationapp;  

  16. excel.Workbookwb;  

  17. excel.Worksheetws;  

  18. excel.Rangerng;  

  19. excel.TextBoxtb;  

  20.  

  21. publicExcel(stringtempletPath)  

  22. {  

  23. //實(shí)例化一個(gè)ExcelApplication對象并使其可見  

  24. beforeTime=DateTime.Now;  

  25. app=newexcel.ApplicationClass();  

  26. app.Visible=true;  

  27. afterTime=DateTime.Now;  

  28.  

  29. wb=app.Workbooks.Open(templetPath,Type.Missing,Type.Missing,Type.
    Missing,Type.Missing,Type.Missing,Type.Missing,Type.Missing,Type.
    Missing,Type.Missing,Type.Missing,Type.Missing,Type.Missing,Type.
    Missing,Type.Missing);  

  30. ws=(excel.Worksheet)wb.Worksheets.get_Item(1);  

  31. }  

  32.  

  33. publicvoidExcelMethod()  

  34. {  

  35. rng=ws.get_Range("B5","C7");  

  36. rng.Merge(excel.XlAxisCrosses.xlAxisCrossesAutomatic);  

  37. rng.Value2="Excel2003";  

  38.  

  39. rng=ws.get_Range("D8","E11");  

  40. rng.MergeCells=true;  

  41. rng.Value2="Excel2003";  

  42. rng.HorizontalAlignment=excel.XlHAlign.xlHAlignCenter;  

  43. rng.VerticalAlignment=excel.XlVAlign.xlVAlignCenter;  

  44.  

  45. rng=ws.get_Range("A1",Type.Missing);  

  46. rng.Value2=5;  

  47.  

  48. rng=ws.get_Range("A2",Type.Missing);  

  49. rng.Value2=7;  

  50.  

  51. for(inti=1;i<100;i++)  

  52. {  

  53. stringstrings=string.Concat("G",i.ToString());  

  54. rng=ws.get_Range(s,Type.Missing);  

  55. rng.Value2=i.ToString();  

  56. }  

  57.  

  58. tb=(excel.TextBox)ws.TextBoxes("文本框1");  

  59. tb.Text="作者";  

  60.  

  61. tb=(excel.TextBox)ws.TextBoxes("文本框2");  

  62. tb.Text="KLY.NET的Blog";  

  63.  

  64. tb=(excel.TextBox)ws.TextBoxes("文本框3");  

  65. tb.Text="日期";  

  66.  

  67.  

  68. try  

  69. {  

  70. tb=(excel.TextBox)ws.TextBoxes("文本框5");  

  71. tb.Text=DateTime.Now.ToShortDateString();  

  72. }  

  73. catch  

  74. {  

  75. //這里用Dispose()方法結(jié)束不了Excel進(jìn)程,所有還是要用Process的Kill()方法配合使用  

  76. //this.Dispose();  

  77. this.KillExcelProcess();  

  78. thrownewException("不存在ID為\"文本框5\"的文本框!");  

  79. }  

  80. finally  

  81. {  

  82. //如果有異常發(fā)生,Dispose()方法放在這里也結(jié)束不了Excel進(jìn)程  

  83. //this.Dispose();  

  84.  

  85. //如果發(fā)生異常,在這里也可以結(jié)束Excel進(jìn)程  

  86. //this.KillExcelProcess();  

  87. }  

  88. }  

  89.  

  90. /**////

     

  91. ///另存為Excel文件  

  92. /// 

  93. ///<paramnameparamname="savePath">保存路徑 

  94. publicvoidSaveAsExcelFile(stringsavePath)  

  95. {  

  96. wb.SaveAs(savePath,excel.XlFileFormat.xlHtml,Type.Missing,Type.
    Missing,Type.Missing,Type.Missing,excel.XlSaveAsAccessMode.xlExclusive,Type.
    Missing,Type.Missing,Type.Missing,Type.Missing,Type.Missing);  

  97. }  

  98.  

  99. /**////

     

  100. ///結(jié)束Excel進(jìn)程  

  101. /// 

  102. publicvoidKillExcelProcess()  

  103. {  

  104. Process[]myProcesses;  

  105. DateTimestartTime;  

  106. myProcesses=Process.GetProcessesByName("Excel");  

  107.  

  108. //得不到Excel進(jìn)程ID,暫時(shí)只能判斷進(jìn)程啟動(dòng)時(shí)間  

  109. foreach(ProcessmyProcessinmyProcesses)  

  110. {  

  111. startTime=myProcess.StartTime;  

  112.  

  113. if(startTime>beforeTime&&startTime)  

  114. {  

  115. myProcess.Kill();  

  116. }  

  117. }  

  118. }  

  119.  

  120. /**////

     

  121. ///如果對Excel的操作沒有引發(fā)異常的話,用這個(gè)方法可以正常結(jié)束Excel進(jìn)程  

  122. ///否則要用KillExcelProcess()方法來結(jié)束Excel進(jìn)程  

  123. /// 

  124. publicvoidDispose()  

  125. {  

  126. wb.Close(null,null,null);  

  127. app.Workbooks.Close();  

  128. app.Quit();  

  129.  

  130. //注意:這里用到的所有Excel對象都要執(zhí)行這個(gè)操作,否則結(jié)束不了Excel進(jìn)程  

  131. if(rng!=null)  

  132. {  

  133. System.Runtime.InteropServices.Marshal.ReleaseComObject(rng);  

  134. rng=null;  

  135. }  

  136. if(tb!=null)  

  137. {  

  138. System.Runtime.InteropServices.Marshal.ReleaseComObject(tb);  

  139. tb=null;  

  140. }  

  141. if(ws!=null)  

  142. {  

  143. System.Runtime.InteropServices.Marshal.ReleaseComObject(ws);  

  144. ws=null;  

  145. }  

  146. if(wb!=null)  

  147. {  

  148. System.Runtime.InteropServices.Marshal.ReleaseComObject(wb);  

  149. wb=null;  

  150. }  

  151. if(app!=null)  

  152. {  

  153. System.Runtime.InteropServices.Marshal.ReleaseComObject(app);  

  154. app=null;  

  155. }  

  156.  

  157. GC.Collect();  

  158. }  

  159. }  

這段代碼能很好的解決Excel進(jìn)程不能正常結(jié)束的問題,如果主機(jī)操作系統(tǒng)不是服務(wù)器版的話,那么就要借助于ntsd -c q -p pid命令來結(jié)束。

還有一個(gè)問題的關(guān)于Excel組件訪問權(quán)限的配置,一定要在組件服務(wù)里面正確配置,否則結(jié)束不了Excel進(jìn)程,具體的配置方法在我項(xiàng)目的doc文件夾下;在我前面的文章里面介紹了在web.config文件里面加入假扮用戶的方法,但是經(jīng)我測試發(fā)現(xiàn)這種方法雖然可以訪問Excel組件,但是結(jié)束不了進(jìn)程,除非用Kill方法強(qiáng)行結(jié)束。

看完上述內(nèi)容是否對您有幫助呢?如果還想對相關(guān)知識(shí)有進(jìn)一步的了解或閱讀更多相關(guān)文章,請關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝您對創(chuàng)新互聯(lián)的支持。


文章題目:ASP.NET中怎么調(diào)用Excel進(jìn)程
文章位置:http://weahome.cn/article/psgdjs.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部