C#中怎么向Excel插入数据

发布时间:2021-07-07 16:19:08 作者:Leah
阅读:783
开发者专用服务器限时活动,0元免费领! 查看>>

本篇文章给大家分享的是有关C#中怎么向Excel插入数据,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。

调用方法:

  1. MengXianhui.Utility.ExcelReport.InsertPictureToExcelipt=
    newMengXianhui.Utility.ExcelReport.InsertPictureToExcel();  

  2. ipt.Open();  

  3. ipt.InsertPicture("B2",@"C:\Excellogo.gif");  

  4. ipt.InsertPicture("B8",@"C:\Excellogo.gif",120,80);  

  5. ipt.SaveFile(@"C:\ExcelTest.xls");  

  6. ipt.Dispose(); 

简单包装的类:

  1. usingSystem;  

  2. usingSystem.Windows.Forms;  

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

  4. namespaceMengXianhui.Utility.ExcelReport  

  5. {  

  6. classInsertPictureToExcel  

  7. {  

  8. ///<summary> 

  9. ///打开没有模板的操作。  

  10. ///</summary> 

  11. publicvoidOpen()  

  12. {  

  13. this.Open(String.Empty);  

  14. }  

  15. ///<summary> 

  16. ///功能:实现Excel应用程序的打开  

  17. ///</summary> 

  18. ///<paramnameparamname="TemplateFilePath">模板文件物理路径</param> 

  19. publicvoidOpen(stringTemplateFilePath)  

  20. {  

  21. //打开对象  

  22. m_objExcel=newExcel.Application();  

  23. m_objExcel.Visible=false;  

  24. m_objExcel.DisplayAlerts=false;  

  25. if(m_objExcel.Version!="11.0")  

  26. {  

  27. MessageBox.Show("您的Excel版本不是11.0(Office2003),操作可能会出现问题。");  

  28. m_objExcel.Quit();  

  29. return;  

  30. }  

  31. m_objBooks=(Excel.Workbooks)m_objExcel.Workbooks;  

  32. if(TemplateFilePath.Equals(String.Empty))  

  33. {  

  34. m_objBook=(Excel._Workbook)(m_objBooks.Add(m_objOpt));  

  35. }  

  36. else  

  37. {  

  38. m_objBook=m_objBooks.Open
    (TemplateFilePath,m_objOpt,m_objOpt,m_objOpt,m_objOpt,m_objOpt,m_objOpt,
    m_objOpt,m_objOpt,m_objOpt,m_objOpt,m_objOpt,m_objOpt,m_objOpt,m_objOpt);  

  39. }  

  40. m_objSheets=(Excel.Sheets)m_objBook.Worksheets;  

  41. m_objSheet=(Excel._Worksheet)(m_objSheets.get_Item(1));  

  42. m_objExcel.WorkbookBeforeClose+=newExcel.
    AppEvents_WorkbookBeforeCloseEventHandler(m_objExcel_WorkbookBeforeClose);  

  43. }  

  44. privatevoidm_objExcel_WorkbookBeforeClose(Excel.Workbookm_objBooks,refbool_Cancel)  

  45. {  

  46. MessageBox.Show("保存完毕!");  

  47. }  

  48. ///<summary> 

  49. ///将图片插入到指定的单元格位置。  

  50. ///注意:图片必须是绝对物理路径  

  51. ///</summary> 

  52. ///<paramnameparamname="RangeName">单元格名称,例如:B4</param> 

  53. ///<paramnameparamname="PicturePath">要插入图片的绝对路径。</param> 

  54. publicvoidInsertPicture(stringRangeName,stringPicturePath)  

  55. {  

  56. m_objRange=m_objSheet.get_Range(RangeName,m_objOpt);  

  57. m_objRange.Select();  

  58. Excel.Picturespics=(Excel.Pictures)m_objSheet.Pictures(m_objOpt);  

  59. pics.Insert(PicturePath,m_objOpt);  

  60. }  

  61. ///<summary> 

  62. ///将图片插入到指定的单元格位置,并设置图片的宽度和高度。  

  63. ///注意:图片必须是绝对物理路径  

  64. ///</summary> 

  65. ///<paramnameparamname="RangeName">单元格名称,例如:B4</param> 

  66. ///<paramnameparamname="PicturePath">要插入图片的绝对路径。</param> 

  67. ///<paramnameparamname="PictuteWidth">插入后,图片在Excel中显示的宽度。</param> 

  68. ///<paramnameparamname="PictureHeight">插入后,图片在Excel中显示的高度。</param> 

  69. publicvoidInsertPicture
    (stringRangeName,stringPicturePath,floatPictuteWidth,floatPictureHeight)  

  70. {  

  71. m_objRange=m_objSheet.get_Range(RangeName,m_objOpt);  

  72. m_objRange.Select();  

  73. floatPicLeft,PicTop;  

  74. PicLeft=Convert.ToSingle(m_objRange.Left);  

  75. PicTop=Convert.ToSingle(m_objRange.Top);  

  76. //参数含义:  

  77. //图片路径  

  78. //是否链接到文件  

  79. //图片插入时是否随文档一起保存  

  80. //图片在文档中的坐标位置(单位:points)  

  81. //图片显示的宽度和高度(单位:points)  

  82. //参数详细信息参见:http://msdn2.microsoft.com/zh-cn/library/aa221765(office.11).aspx  

  83. m_objSheet.Shapes.AddPicture(PicturePath,Microsoft.Office.Core.MsoTriState.
    msoFalse,Microsoft.Office.Core.MsoTriState.msoTrue,PicLeft,PicTop,
    PictuteWidth,PictureHeight);  

  84. }  

  85. ///<summary> 

  86. ///将Excel文件保存到指定的目录,目录必须事先存在,文件名称不一定要存在。  

  87. ///</summary> 

  88. ///<paramnameparamname="OutputFilePath">要保存成的文件的全路径。</param> 

  89. publicvoidSaveFile(stringOutputFilePath)  

  90. {  

  91. m_objBook.SaveAs(OutputFilePath,m_objOpt,m_objOpt,  

  92. m_objOpt,m_objOpt,m_objOpt,Excel.XlSaveAsAccessMode.xlNoChange,  

  93. m_objOpt,m_objOpt,m_objOpt,m_objOpt,m_objOpt);  

  94. this.Close();  

  95. }  

  96. ///<summary> 

  97. ///关闭应用程序  

  98. ///</summary> 

  99. privatevoidClose()  

  100. {  

  101. m_objBook.Close(false,m_objOpt,m_objOpt);  

  102. m_objExcel.Quit();  

  103. }  

  104. ///<summary> 

  105. ///释放所引用的COM对象。注意:这个过程一定要执行。  

  106. ///</summary> 

  107. publicvoidDispose()  

  108. {  

  109. ReleaseObj(m_objSheets);  

  110. ReleaseObj(m_objBook);  

  111. ReleaseObj(m_objBooks);  

  112. ReleaseObj(m_objExcel);  

  113. System.GC.Collect();  

  114. System.GC.WaitForPendingFinalizers();  

  115. }  

  116. ///<summary> 

  117. ///释放对象,内部调用  

  118. ///</summary> 

  119. ///<paramnameparamname="o"></param> 

  120. privatevoidReleaseObj(objecto)  

  121. {  

  122. try  

  123. {  

  124. System.Runtime.InteropServices.Marshal.ReleaseComObject(o);  

  125. }  

  126. catch{}  

  127. finally{o=null;}  

  128. }  

  129. privateExcel.Applicationm_objExcel=null;  

  130. privateExcel.Workbooksm_objBooks=null;  

  131. privateExcel._Workbookm_objBook=null;  

  132. privateExcel.Sheetsm_objSheets=null;  

  133. privateExcel._Worksheetm_objSheet=null;  

  134. privateExcel.Rangem_objRange=null;  

  135. privateobjectm_objOpt=System.Reflection.Missing.Value;  

  136. }  

以上就是C#中怎么向Excel插入数据,小编相信有部分知识点可能是我们日常工作会见到或用到的。希望你能通过这篇文章学到更多知识。更多详情敬请关注亿速云行业资讯频道。

亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>

推荐阅读:
  1. 利用Jmeter向MySQL批量插入数据
  2. 如何批量向表中插入数据?

开发者交流群:

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

excel

上一篇:C#中有哪些移位运算符

下一篇:C# 中怎么利用ODBC访问MySQL数据库

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》
开发者交流群×