DataTable Excel

这里是使用Microsoft.Office.Interop.Excel类进行Excel表格操作,核心代码就这些了。麻烦的是服务器上的一些关于access的权限配置。             

   string file = System.AppDomain.CurrentDomain.BaseDirectory + "对账单\\" + filename;

                if (ExcelHelper.DataTableToCSV(dt, file + System.Web.HttpContext.Current.Session["us_Name"] + ".csv", new string[] { "rowId" }))
                {
                    HttpResponse resp;
                    resp = System.Web.HttpContext.Current.Response;
                    resp.Clear();
                    resp.ContentEncoding = System.Text.Encoding.GetEncoding("GB2312");
                    resp.ContentType = "application/vnd.ms-excel";
                    resp.Charset = "GB2312";

                    resp.AppendHeader("Content-Disposition", "attachment;filename=" + HttpUtility.UrlEncode(filename, Encoding.UTF8) + ".csv");
                    resp.WriteFile(file + System.Web.HttpContext.Current.Session["us_Name"] + ".csv");
                }

 

        public static bool DataTableToCSV(System.Data.DataTable excelTable, string filePath,string[] removeFileds)
        {

            Microsoft.Office.Interop.Excel.Application app = new Microsoft.Office.Interop.Excel.ApplicationClass();
            app.Visible = false;

            Workbooks workBooks = app.Workbooks; //创建Excel工作簿
            Workbook wBook = workBooks.Add(XlWBATemplate.xlWBATWorksheet);

            Worksheet wSheet = wBook.Worksheets[1] as Worksheet;

            foreach (string item in removeFileds)
            {
                if (excelTable.Columns.Contains(item))
                {
                    excelTable.Columns.Remove(item);
                }
            }

            try
            {


                if (excelTable.Rows.Count > 0)
                {
                    int row = 0;
                    row = excelTable.Rows.Count;
                    int col = excelTable.Columns.Count;

                    //关键性代码,直接关系到性能问题
            Array arr = Array.CreateInstance(typeof(String), row, col);

                    for (int i = 0; i < row; i++)
                    {

                        for (int j = 0; j < col; j++)
                        {

                            arr.SetValue(excelTable.Rows[i][j].ToString(), i, j);

                        }

                    }

                    Microsoft.Office.Interop.Excel.Range range = wSheet.get_Range(wSheet.Cells[2, 1], wSheet.Cells[row + 1, col]);
                    range.Value2 = arr; 
                }

                int size = excelTable.Columns.Count;
                for (int k = 0; k < size; k++)
                {

                    wSheet.Cells[1, 1 + k] = excelTable.Columns[k].ColumnName;
                    Range xlsRang = (Range)wSheet.Cells[1, 1 + k];
                    xlsRang.EntireColumn.AutoFit();
                }

                //设置禁止弹出保存和覆盖的询问提示框   
                app.DisplayAlerts = false;
                app.AlertBeforeOverwriting = false;
                //保存工作簿   

                wBook.Save();
                wBook.SaveCopyAs(filePath); //自定义保存的文件名称

            }
            catch (Exception err)
            {
                return false;
            }
            finally
            {

                workBooks.Close(); //关闭工作簿
                if (app != null)
                {
                    app.Workbooks.Close();
                    app.Quit(); //退出Excel
                    int intGenerate = System.GC.GetGeneration(app);
                    System.Runtime.InteropServices.Marshal.ReleaseComObject(app); //将XLSAPP从内存托管堆中移除
                    app = null;
                    System.GC.Collect(intGenerate);
                }
                GC.Collect(); //强行退出Excel
                app = null;

            }

            return true;
        }

 

posted on 2011-12-13 11:36  飞舞的蒲公英  阅读(422)  评论(0编辑  收藏  举报