C# Excel导入导出

 

 

 /// <summary>
        /// 导出Excel
        /// </summary>
        /// <typeparam name="T"></typeparam>
        /// <param name="list">数据源List<T></param>
        /// <param name="fileName">页面文件 输出名称 *.xls</param>
        public void Export<T>(IList<T> list, string fileName)
        {

            //得到DataTable
            System.Data.DataTable dt = ListToTableHelper.ToDataTable(list);

            //导出Excel的临时文件
            string exportPath = Server.MapPath("~/Excel/") + DateTime.Now.Ticks + fileName;

            CreateExcel(dt, exportPath);
            FileInfo fileInfo = new FileInfo(exportPath);
            if (fileInfo.Exists)
            {
                const long ChunkSize = 102400;//100K 每次读取文件,只读取100K,这样可以缓解服务器的压力
                byte[] buffer = new byte[ChunkSize];
                Response.Clear();
                System.IO.FileStream iStream = System.IO.File.OpenRead(exportPath);
                long dataLengthToRead = iStream.Length;//获取下载的文件总大小
                Response.ContentType = "application/octet-stream";
                Response.AddHeader("Content-Disposition", "attachment; filename=" + HttpUtility.UrlEncode(fileName));
                while (dataLengthToRead > 0 && Response.IsClientConnected)
                {
                    int lengthRead = iStream.Read(buffer, 0, Convert.ToInt32(ChunkSize));//读取的大小
                    Response.OutputStream.Write(buffer, 0, lengthRead);
                    Response.Flush();
                    dataLengthToRead = dataLengthToRead - lengthRead;
                }
                iStream.Close();
                Response.Close();
            }

            // 删除生成的Excel 临时文件
            File.Delete(exportPath);



        }

 

 

 

 /// <summary>
        /// 打开模板Excel,重新写入 另存Excel 文件格式 xls 97-2003
        /// </summary>
        /// <param name="dt"></param>
        /// <param name="excelPath"></param>
        /// <param name="tempExcelPath"></param>
        public void CreateExcel(System.Data.DataTable dt, string savePath)
        {
            savePath = savePath.Replace("/", "\\");
            Application application = new ApplicationClass();
            application.Visible = false;


            //创建 新的Excel
            Workbook workbook = application.Workbooks.Add(Microsoft.Office.Interop.Excel.XlWBATemplate.xlWBATWorksheet);

            //插入 现有的Excel
            //application.Workbooks._Open(tempExcelPath, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value);
            Worksheet worksheet = (Worksheet)workbook.Sheets[1];
            int rowNum = 1;
            int excelColumNum = 0;
            try
            {
                int count = dt.Rows.Count;


                for (int i = 0; i < dt.Columns.Count; i++)
                {
                    worksheet.Cells[1, i + 1] = dt.Columns[i].ColumnName;
                    Range range = (Microsoft.Office.Interop.Excel.Range)worksheet.Cells[1, i + 1];
                    range.Interior.ColorIndex = 15;
                    range.Font.Bold = true;
                }

                foreach (System.Data.DataRow row in dt.Rows)
                {
                    rowNum++;
                    //Console.WriteLine("当前处理记录:{0}/{1}", rowNum, count);
                    for (int i = 1; i <= dt.Columns.Count; i++)
                    {
                        excelColumNum = i;
                        string text = row[i - 1].ToString();
                        Range range = (Range)worksheet.Cells[rowNum, excelColumNum];
                        range.Value2 = text;
                    }
                }
                workbook.Saved = true;
                workbook.SaveAs(savePath, XlFileFormat.xlExcel8, Missing.Value, Missing.Value, Missing.Value, Missing.Value, XlSaveAsAccessMode.xlNoChange, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value);

                workbook.Close(true, Type.Missing, Type.Missing);
                workbook = null;
                application.Quit();
                GC.Collect();
            }
            catch
            {
                workbook.Saved = false;
                workbook.Close(true, Type.Missing, Type.Missing);
                workbook = null;
                application.Quit();
                GC.Collect();
            }

        }

 

调用:

 protected void btn_ExportExcel_Click(object sender, EventArgs e)
        {
            
            IList<SongInfo> list = new List<SongInfo>();// 数据源


            string fileName = "data.xls"; //页面文件 输出名称
            Export(list, fileName);  //调用方法

            ScriptManager.RegisterStartupScript(this, this.GetType(), "", "alert('成功!')", true); //完成后显示消息
        }

  

 

 

 

posted @ 2014-02-28 10:36  兴想事成  阅读(179)  评论(0编辑  收藏  举报