前言
做了好几个Excel、Word导出,用了HTTP流导出伪Excel文件、用过Office组件(这东西在生产环境下相当麻烦,各种权限,**)。
最后决定使用NPOI组件来导出,好处很多很多了,这里不多说。
这篇文章呢,主要说一下Excel导出的细节以及问题。
我在制作这个Demo的时候使用的环境:
Visual Studio 2010、Office 2013 、Framework .NET 3.5 、NPOI 1.2.5(至于为什么没有选最新版 稍后说)
完成后的截图
从浏览器导出的Excel,打开并没有提示文件格式不对,这是真真的Excel格式。
从上图看出,列是自动适应了宽度了的,不会挤到一堆。
CreateSheet帮助类
/// <summary> /// 创建工作簿 /// </summary> /// <param name="fileName">下载文件名</param> /// <param name="dt">数据源</param> public static void CreateSheet(string fileName, DataTable dt) { HSSFWorkbook workbook = new HSSFWorkbook(); MemoryStream ms = new MemoryStream(); //创建一个名称为Payment的工作表 ISheet paymentSheet = workbook.CreateSheet("Payment"); //数据源 DataTable tbPayment = dt; //头部标题 IRow paymentHeaderRow = paymentSheet.CreateRow(0); //循环添加标题 foreach (DataColumn column in tbPayment.Columns) paymentHeaderRow.CreateCell(column.Ordinal).SetCellValue(column.ColumnName); // 内容 int paymentRowIndex = 1; foreach (DataRow row in tbPayment.Rows) { IRow newRow = paymentSheet.CreateRow(paymentRowIndex); //循环添加列的对应内容 foreach (DataColumn column in tbPayment.Columns) { newRow.CreateCell(column.Ordinal).SetCellValue(row[column].ToString()); } paymentRowIndex++; } //列宽自适应,只对英文和数字有效 for (int i = 0; i <= dt.Rows.Count; i++) { paymentSheet.AutoSizeColumn(i); } //获取当前列的宽度,然后对比本列的长度,取最大值 for (int columnNum = 0; columnNum <= dt.Columns.Count; columnNum++) { int columnWidth = paymentSheet.GetColumnWidth(columnNum) / 256; for (int rowNum = 1; rowNum <= paymentSheet.LastRowNum; rowNum++) { IRow currentRow; //当前行未被使用过 if (paymentSheet.GetRow(rowNum) == null) { currentRow = paymentSheet.CreateRow(rowNum); } else { currentRow = paymentSheet.GetRow(rowNum); }