zoukankan      html  css  js  c++  java
  • [置顶]C#执行Excel宏模版的方法

           在项目中如果涉及到用Excel开发的报表模版来导出报表数据的话,一般都是在Excel报表中使用VBA做成宏来进行调用。即先使用Excel自带的VBA开发好报表模版,然后再将模版程序放在固定目录下,在管理软件中对这些报表模版进行调用。这样就不需要使用其它报表工具来进行开发了,因为Excel功能比较强大,一般的应用的报表用它来开发绰绰有余了。而且这样开发的成本也很低,不需要再购买其它专业的报表开发软件直接使用Office开发即可。使用Excel开发的宏模版当然要使用上层程序来调用宏模版了。我以前在工作中就开发过Excel模版,并使用C#程序调用过这些模版程序。规则是首先将报表需要的数据填冲到DataTable或者DataSet中,然后将DataTable或者DataSet中数据导出Excel中。

    现提供导出Excel模版的代码如下:

    namespace ExcelTest
    {
        public class ExelTemplate
        {
            private static Excel.Application ExcelApp;//Define a Excel Application object
            private static Excel._Workbook ExcelWB;//define a Excel workbook object
            private static Excel._Worksheet ExcelWS;//define a Excel workbook worksheet

           //将报表所需的主数据放入dtHeader,明细数据放入dtDetail中,调用的模版名称为strTemplateFileName,导出的报表名称为strOutFileName

            public static bool FillContent(string strTemplateFileName, string strOutFileName, System.Data.DataTable dtHeader, System.Data.DataTable dtDetail)
            {

                bool flag = true;
                FileInfo fileInfo = new FileInfo(strTemplateFileName);

                System.Globalization.CultureInfo CurrentCI = System.Threading.Thread.CurrentThread.CurrentCulture;
                System.Threading.Thread.CurrentThread.CurrentCulture = new System.Globalization.CultureInfo("en-US");

                try
                {
                    //Start Excel and get Application object.               
                    ExcelApp = new Excel.Application();
                    ExcelApp.Visible  = false;
                 
                    //Get a new workbook.
                    ExcelWB = (Excel._Workbook)(ExcelApp.Workbooks.Add(strTemplateFileName));
                   

                    //Fill content.注意这里的Header和Detail分别对应模版文件中的Header和Detail两个Sheet页,这2个Sheet是专门用来存放明主数据或者明细数据的。
                    if (!FillWorksheet("Header", dtHeader)) return false;
                    if (!FillWorksheet("Detail", dtDetail)) return false;

                    //Run macro.
                   
                    ExcelApp.Run("SetData", Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value);
                  
                    ExcelApp.DisplayAlerts = false;
                    //=========================================================================================================
                    //Delete Header and Detail.
                    //((Excel._Worksheet)ExcelWB.Sheets["Header Information"]).Delete();               
                    //((Excel._Worksheet)ExcelWB.Sheets["Detail Information"]).Delete();


                    //=========================================================================================================
                    ExcelApp.DisplayAlerts = true;

                    //Delete old file.
                    File.Delete(strOutFileName);
                    //Save excel file.
                    ExcelWB.SaveAs(strOutFileName, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, XlSaveAsAccessMode.xlExclusive, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value);
                   
                    // Quit Excel.
                    ExcelWB.Close(false, strOutFileName, Missing.Value);//*******************             

                    MarshalReleaseComObject(ExcelWB);

                    ExcelApp.Quit();
                   
                   
                    //Kill excel application.
                    //KillProcess("EXCEL");//******************
                  
                }
                catch (Exception ex)
                {
                    throw ex;  
                    flag = false;
                }
                finally
                {
                    MarshalReleaseComObject(ExcelApp);
                    GC.Collect();
                }

                return flag;
            }

            //将报表所需的主数据放入dtHeader,明细数据放入dtDetail中,调用的模版名称为strTemplateFileName,导出的报表名称为strOutFileName

            public static bool FillContent(string strTemplateFileName, string strOutFileName, System.Data.DataSet dsdata)
            {

                bool flag = true;
                FileInfo fileInfo = new FileInfo(strTemplateFileName);

                System.Globalization.CultureInfo CurrentCI = System.Threading.Thread.CurrentThread.CurrentCulture;
                System.Threading.Thread.CurrentThread.CurrentCulture = new System.Globalization.CultureInfo("en-US");

                try
                {
                    //Start Excel and get Application object.               
                    ExcelApp = new Excel.Application();
                    ExcelApp.Visible = false;

                    //Get a new workbook.
                     ExcelWB = (Excel._Workbook)(ExcelApp.Workbooks.Add(strTemplateFileName));
                     //Fill content.
                    //if (!FillWorksheet("Header", dtHeader)) return false;
                    //if (!FillWorksheet("Detail", dtDetail)) return false;

                    //Fill content.注意这里的没有写明对应模版文件中Sheet页,但是指定了dsdata.Tables[i].TableName为Sheet页的名字,这样方便灵活设置,而且这样可以有多个Sheet是专门用来存放明主数据或者明细数据的。
                    for (int i = 0; i < dsdata.Tables.Count; i++)
                    {
                        if (!FillWorksheet(dsdata.Tables[i].TableName, dsdata.Tables[i]))
                            return false;
                    }

                    //Run macro.
                 
                    ExcelApp.Run("SetData", Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value);
                   
                    ExcelApp.DisplayAlerts = false;
                    //=========================================================================================================
                    //Delete Header and Detail.
                    //((Excel._Worksheet)ExcelWB.Sheets["Header Information"]).Delete();               
                    //((Excel._Worksheet)ExcelWB.Sheets["Detail Information"]).Delete();


                    //=========================================================================================================
                    ExcelApp.DisplayAlerts = true;

                    //Delete old file.
                    File.Delete(strOutFileName);
                    //Save excel file.
                   
                    ExcelWB.SaveAs(strOutFileName, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, XlSaveAsAccessMode.xlExclusive, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value);
                   
                    // Quit Excel.
                    ExcelWB.Close(false, strOutFileName, Missing.Value);//*******************             

                    MarshalReleaseComObject(ExcelWB);

                    ExcelApp.Quit();
                 

                }
                catch (Exception ex)
                {
                    throw ex;
                    flag = false;
                }
                finally
                {
                    MarshalReleaseComObject(ExcelApp);
                    GC.Collect();
                }

                return flag;
            }

            //使用Excel来导出报表时,在服务器上的Excel进程容易死掉,导致资源无法释放,因此需要使用这个方法来释放死掉的进程

            private static void MarshalReleaseComObject(object objCom)
            {
                try
                {
                    int i = 1;
                    if (objCom != null && System.Runtime.InteropServices.Marshal.IsComObject(objCom))
                    {
                        do
                        {
                            i = System.Runtime.InteropServices.Marshal.ReleaseComObject(objCom);
                        } while (i > 0);
                    }
                }
                finally
                {
                    objCom = null;
                }
            }

    }

             

  • 相关阅读:
    WebService之使用CXF偶遇的BUG
    修改Web项目的名称后,在TomCat中部署项目,项目的名称还是与原来相同的解决方案
    JAVA面试题一 之 io流的操作
    第四天 字符串的格式化输出
    第三天 while循环 及其用法
    第二天 注释 、运算符,文件扩展名
    第一天 python入门 基础 “”“Hello World”和if-elif的使用、数据类型
    62. (待补)统计一个字符在字符串中出现次数 与 统计一个字符串在另一字符串中出现次数。
    61. 解析linux密码配置文件,获取配置文件信息,每行归纳为一个指针数组存入内存, 练习文件,数组,指针,字符串处理相关的配合使用要点
    60. 去字符串中的空格,去左空格,去右空格,去全部空格。
  • 原文地址:https://www.cnblogs.com/kevinGao/p/2192942.html
Copyright © 2011-2022 走看看