在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
/// <summary> /// 导出Excel /// </summary> public void ExportExcel() { #region 添加引用 Microsoft.Office.Interop.Excel.Application app = new Microsoft.Office.Interop.Excel.Application();//需要添加 Microsoft.Office.Interop.Excel引用 if (app == null) return;//app == null ,则代表服务器上“服务器上缺少Excel组件,需要安装Office软件” #endregion #region 设置app属性 app.Visible = false; app.UserControl = true; Microsoft.Office.Interop.Excel.Workbooks workbooks = app.Workbooks; Microsoft.Office.Interop.Excel._Workbook workbook = workbooks.Add(Server.MapPath("~/Template/Template.xls")); //加载模板 Microsoft.Office.Interop.Excel.Sheets sheets = workbook.Sheets; Microsoft.Office.Interop.Excel._Worksheet worksheet = null; Microsoft.Office.Interop.Excel.Range range = null; worksheet = (Microsoft.Office.Interop.Excel._Worksheet)sheets.get_Item(1);//获取第一个Sheet页 if (worksheet == null) worksheet = (Microsoft.Office.Interop.Excel._Worksheet)workbook.Worksheets.Add(System.Type.Missing, System.Type.Missing, System.Type.Missing, System.Type.Missing); #endregion #region 根据获得的数据,进行数据的插入(到Excel模板中) var _row = 15;//从第15行开始导入列表 //合并A14到K14 range = worksheet.get_Range("A" + (_row - 1), "K" + (_row - 1)); range.Merge(range.MergeCells); //取得数据集,并导入Excel DataTable table = new DataTable(); for (int i = _row; i < table.Rows.Count + _row; i++) { worksheet.Cells[_row, 1] = "第_row行 第一列"; worksheet.Cells[_row, 2] = "第_row行 第二列"; } //插入行 range = (Microsoft.Office.Interop.Excel.Range)worksheet.Rows[_row, Missing.Value]; range.Insert(Microsoft.Office.Interop.Excel.XlInsertShiftDirection.xlShiftDown, Missing.Value); #endregion #region 对已导出好的Excel报表进行保存到服务器,以便进行下载 if (!Directory.Exists(Server.MapPath("~/Excel/"))) Directory.CreateDirectory(Server.MapPath("~/Excel/")); string savaPath = "~/Excel/" + DateTime.Now.ToString("yyyyMMddHHmmss") + ".xls"; workbook.SaveAs(Server.MapPath(savaPath), Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Microsoft.Office.Interop.Excel.XlSaveAsAccessMode.xlNoChange, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value);//Missing 在System.Reflection命名空间下。 #endregion #region 释放资源 // 关闭电子表格,释放资源 workbook.Close(null, null, null); app.Workbooks.Close(); workbook = null; // 退出 Excel,释放资源 app.Quit(); app = null; GC.Collect(); #endregion #region 下载Excel Response.ContentType = "application/x-zip-compressed"; Response.AddHeader("Content-Disposition", "attachment;filename=" + DateTime.Now.ToString("yyyyMMddHHmmss") + ".xls"); Response.TransmitFile(savaPath); Response.Flush(); Response.Close(); #endregion } /// <summary> /// 用于excel表格中列号字母转成列索引,从1对应A开始 /// </summary> /// <param name="column">列号</param> /// <returns>列索引</returns> private int ColumnToIndex(string column) { if (!Regex.IsMatch(column.ToUpper(), @"[A-Z]+")) { throw new Exception("Invalid parameter"); } int index = 0; char[] chars = column.ToUpper().ToCharArray(); for (int i = 0; i < chars.Length; i++) { index += ((int)chars[i] - (int)'A' + 1) * (int)Math.Pow(26, chars.Length - i - 1); } return index; } /// <summary> /// 用于将excel表格中列索引转成列号字母,从A对应1开始 /// </summary> /// <param name="index">列索引</param> /// <returns>列号</returns> private string IndexToColumn(int index) { if (index <= 0) { throw new Exception("Invalid parameter"); } index--; string column = string.Empty; do { if (column.Length > 0) { index--; } column = ((char)(index % 26 + (int)'A')).ToString() + column; index = (int)((index - index % 26) / 26); } while (index > 0); return column; }
参考文档 <http://www.cnblogs.com/herbert/archive/2010/06/30/1768271.html> |
请发表评论