ExcelHelper.cs 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116
  1. using NPOI.HPSF;
  2. using NPOI.HSSF.UserModel;
  3. using NPOI.SS.UserModel;
  4. using ProjectBase.Data.Logs;
  5. using System;
  6. using System.IO;
  7. namespace ProjectBase.Data.Excel
  8. {
  9. public interface IReportExport
  10. {
  11. void GenerateData(HSSFWorkbook templatebook);
  12. }
  13. public class ExcelHelper
  14. {
  15. private HSSFWorkbook hssfworkbook;
  16. private string Filename;
  17. private string Templatename;
  18. private IReportExport exportor;
  19. public void InitializeWorkbook()
  20. {
  21. string TemplatePath = string.Format("{0}", Templatename);
  22. FileStream file = new FileStream(@TemplatePath, FileMode.Open, FileAccess.Read);
  23. hssfworkbook = new HSSFWorkbook(file);
  24. //create a entry of DocumentSummaryInformation
  25. NPOI.HPSF.DocumentSummaryInformation dsi = PropertySetFactory.CreateDocumentSummaryInformation();
  26. dsi.Company = "siasun";
  27. hssfworkbook.DocumentSummaryInformation = dsi;
  28. //create a entry of SummaryInformation
  29. SummaryInformation si = PropertySetFactory.CreateSummaryInformation();
  30. si.Subject = "Gem System";
  31. hssfworkbook.SummaryInformation = si;
  32. }
  33. protected MemoryStream WriteToStream()
  34. {
  35. MemoryStream file = new MemoryStream();
  36. hssfworkbook.Write(file);
  37. return file;
  38. }
  39. public ISheet PrintSheet()
  40. {
  41. return hssfworkbook.GetSheet(Templatename);
  42. }
  43. public void WriteToFile()
  44. {
  45. //删除文件
  46. System.IO.File.Delete(Filename);// 删除文件
  47. FileStream file = new FileStream(Filename, FileMode.Create);
  48. hssfworkbook.Write(file);
  49. file.Close();
  50. // return file;
  51. }
  52. /// <summary>
  53. ///
  54. /// </summary>
  55. /// <param name="filename">导出的文件名</param>
  56. /// <param name="templatefile">模板文件路径</param>
  57. /// <param name="exp">适配器</param>
  58. public ExcelHelper(string filename, string templatefile, IReportExport exp)
  59. {
  60. Filename = filename;
  61. Templatename = templatefile;
  62. exportor = exp;
  63. }
  64. protected void GenerateData(HSSFWorkbook templatebook)
  65. {
  66. exportor.GenerateData(templatebook);
  67. }
  68. public bool ExportSheet()
  69. {
  70. try
  71. {
  72. InitializeWorkbook();
  73. this.GenerateData(hssfworkbook);
  74. }
  75. catch (Exception ex)
  76. {
  77. LogHelper.log.Error(Templatename + "保存文档失败,失败原因为", ex);
  78. return false;
  79. }
  80. return true;
  81. }
  82. public bool Export()
  83. {
  84. try
  85. {
  86. InitializeWorkbook();
  87. this.GenerateData(hssfworkbook);
  88. WriteToFile();
  89. }
  90. catch (Exception ex)
  91. {
  92. LogHelper.log.Error(Templatename + "保存文档失败,失败原因为", ex);
  93. return false;
  94. }
  95. return true;
  96. }
  97. }
  98. }