最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

asp.net 利用NPOI导出Excel通用类的方法

来源:动视网 责编:小采 时间:2020-11-27 22:35:33
文档

asp.net 利用NPOI导出Excel通用类的方法

asp.net 利用NPOI导出Excel通用类的方法:解决中文文件名保存Excel乱码问题,主要是判断火狐或者IE浏览器,然后做对应的判断处理,核心代码如下: System.Web.HttpContext.Current.Response.ContentType = application/vnd.ms-excel; //设置下载的Excel文件名\ if (
推荐度:
导读asp.net 利用NPOI导出Excel通用类的方法:解决中文文件名保存Excel乱码问题,主要是判断火狐或者IE浏览器,然后做对应的判断处理,核心代码如下: System.Web.HttpContext.Current.Response.ContentType = application/vnd.ms-excel; //设置下载的Excel文件名\ if (


解决中文文件名保存Excel乱码问题,主要是判断火狐或者IE浏览器,然后做对应的判断处理,核心代码如下:

 System.Web.HttpContext.Current.Response.ContentType = "application/vnd.ms-excel"; 
 //设置下载的Excel文件名\ 
 if (System.Web.HttpContext.Current.Request.ServerVariables["http_user_agent"].ToString().IndexOf("Firefox") != -1) 
 { 
 //火狐浏览器 
 System.Web.HttpContext.Current.Response.AddHeader("Content-Disposition", string.Format("attachment;filename={0}", "=?UTF-8?B?" + Convert.ToBase64String(System.Text.Encoding.UTF8.GetBytes(fileName)) + "?=")); 
} 
else 
{ 
 //IE等浏览器 
 System.Web.HttpContext.Current.Response.AddHeader("Content-Disposition", string.Format("attachment;filename={0}", System.Web.HttpUtility.UrlEncode(fileName, System.Text.Encoding.UTF8))); 
} 

废话不多说,直接上类库代码,ATNPOIHelper.cs:

using System; 
using System.Linq; 
using System.Web; 
using System.IO; 
using NPOI; 
using NPOI.SS.Util; 
using NPOI.HSSF.Util; 
using NPOI.SS.UserModel; 
using NPOI.HSSF.UserModel; 
using System.Data; 
using System.Collections.Generic; 
using System.Text; 
 
namespace AT.Utility.DotNetFile 
{ 
 /* 
 导出Excel包含的功能: 
 1.多表头导出最多支持到三行,表头格式说明 
 相邻父列头之间用'#'分隔,父列头与子列头用空格(' ‘)分隔,相邻子列头用逗号分隔(‘,') 
 两行:序号#分公司#组别#本日成功签约单数 预警,续约,流失,合计#累计成功签约单数 预警,续约,流失,合计#任务数#完成比例#排名 
 三行:等级#级别#上期结存 件数,重量,比例#本期调入 收购调入 件数,重量,比例#本期发出 车间投料 件数,重量,比例#本期发出 产品外销百分比 件数,重量,比例#平均值 
 三行时请注意:列头要重复 
 2.添加表头标题功能 
 3.添加序号功能 
 4.根据数据设置列宽 
 
 缺陷: 
 数据内容不能合并列合并行 
 
 改进思路: 
 添加一属性:设置要合并的列,为了实现多列合并可以这样设置{“列1,列2”,”列4”} 
 */ 
 /// <summary> 
 /// 利用NPOI实现导出Excel 
 /// </summary> 
 public class ATNPOIHelper 
 { 
 
 #region 初始化 
 
 /// <summary> 
 /// 声明 HSSFWorkbook 对象 
 /// </summary> 
 private static HSSFWorkbook _workbook; 
 
 /// <summary> 
 /// 声明 HSSFSheet 对象 
 /// </summary> 
 private static HSSFSheet _sheet; 
 
 #endregion 
 
 #region Excel导出 
 
 /// <summary> 
 /// Excel导出 
 /// </summary> 
 /// <param name="fileName">文件名称 如果为空或NULL,则默认“新建Excel.xls”</param> 
 /// <param name="list"></param> 
 /// <param name="ColMergeNum">合计:末行合计时,合并的列数</param> 
 /// <param name="method">导出方式 1:WEB导出(默认)2:按文件路径导出</param> 
 /// <param name="filePath">文件路径 如果WEB导出,则可以为空;如果按文件路径导出,则默认桌面路径</param> 
 public static void Export(string fileName, IList<NPOIModel> list, int ColMergeNum, int method = 1, string filePath = null) 
 { 
 // 文件名称 
 if (!string.IsNullOrEmpty(fileName)) 
 { 
 if (fileName.IndexOf('.') == -1) 
 { 
 fileName += ".xls"; 
 } 
 else 
 { 
 fileName = fileName.Substring(1, fileName.IndexOf('.')) + ".xls"; 
 } 
 } 
 else 
 { 
 fileName = "新建Excel.xls"; 
 } 
 // 文件路径 
 if (2 == method && string.IsNullOrEmpty(filePath)) 
 { 
 filePath = Environment.GetFolderPath(Environment.SpecialFolder.Desktop); 
 } 
 // 调用导出处理程序 
 Export(list, ColMergeNum); 
 // WEB导出 
 if (1 == method) 
 { 
 System.Web.HttpContext.Current.Response.ContentType = "application/vnd.ms-excel"; 
 //设置下载的Excel文件名\ 
 if (System.Web.HttpContext.Current.Request.ServerVariables["http_user_agent"].ToString().IndexOf("Firefox") != -1) 
 { 
 //火狐浏览器 
 System.Web.HttpContext.Current.Response.AddHeader("Content-Disposition", string.Format("attachment;filename={0}", "=?UTF-8?B?" + Convert.ToBase64String(System.Text.Encoding.UTF8.GetBytes(fileName)) + "?=")); 
 } 
 else 
 { 
 //IE等浏览器 
 System.Web.HttpContext.Current.Response.AddHeader("Content-Disposition", string.Format("attachment;filename={0}", System.Web.HttpUtility.UrlEncode(fileName, System.Text.Encoding.UTF8))); 
 } 
 using (MemoryStream ms = new MemoryStream()) 
 { 
 //将工作簿的内容放到内存流中 
 _workbook.Write(ms); 
 //将内存流转换成字节数组发送到客户端 
 System.Web.HttpContext.Current.Response.BinaryWrite(ms.GetBuffer()); 
 System.Web.HttpContext.Current.Response.End(); 
 _sheet = null; 
 _workbook = null; 
 } 
 } 
 else if (2 == method) 
 { 
 using (FileStream fs = File.Open(filePath, FileMode.Append)) 
 { 
 _workbook.Write(fs); 
 _sheet = null; 
 _workbook = null; 
 } 
 } 
 } 
 
 /// <summary> 
 /// 导出方法实现 
 /// </summary> 
 /// <param name="list"></param> 
 private static void Export(IList<NPOIModel> list, int ColMergeNum) 
 { 
 
 #region 变量声明 
 
 // 初始化 
 _workbook = new HSSFWorkbook(); 
 // 声明 Row 对象 
 IRow _row; 
 // 声明 Cell 对象 
 ICell _cell; 
 // 总列数 
 int cols = 0; 
 // 总行数 
 int rows = 0; 
 // 行数计数器 
 int rowIndex = 0; 
 // 单元格值 
 string drValue = null; 
 
 #endregion 
 
 foreach (NPOIModel model in list) 
 { 
 // 工作薄命名 
 if (model.sheetName != null) 
 _sheet = (HSSFSheet)_workbook.CreateSheet(model.sheetName); 
 else 
 _sheet = (HSSFSheet)_workbook.CreateSheet(); 
 
 // 获取数据源 
 DataTable dt = model.dataSource; 
 // 初始化 
 rowIndex = 0; 
 // 获取总行数 
 rows = GetRowCount(model.headerName); 
 // 获取总列数 
 cols = GetColCount(model.headerName); 
 
 //合计:合并表格末行N列,rows为表头行数,dt.Rows.Count为数据行数 
 if (ColMergeNum > 1) 
 { 
 CellRangeAddress region_Merge = new CellRangeAddress(rows + dt.Rows.Count, rows + dt.Rows.Count, 0, ColMergeNum - 1); 
 _sheet.AddMergedRegion(region_Merge); 
 } 
 
 ICellStyle myBodyStyle = bodyStyle; 
 ICellStyle myTitleStyle = titleStyle; 
 ICellStyle myDateStyle = dateStyle; 
 ICellStyle myBodyRightStyle = bodyRightStyle; 
 // 循环行数 
 foreach (DataRow row in dt.Rows) 
 { 
 
 #region 新建表,填充表头,填充列头,样式 
 
 if (rowIndex == 65535 || rowIndex == 0) 
 { 
 if (rowIndex != 0) 
 _sheet = (HSSFSheet)_workbook.CreateSheet(); 
 
 // 构建行 
 for (int i = 0; i < rows + model.isTitle; i++) 
 { 
 _row = _sheet.GetRow(i); 
 // 创建行 
 if (_row == null) 
 _row = _sheet.CreateRow(i); 
 
 for (int j = 0; j < cols; j++) 
 _row.CreateCell(j).CellStyle = myBodyStyle; 
 } 
 
 // 如果存在表标题 
 if (model.isTitle > 0) 
 { 
 // 获取行 
 _row = _sheet.GetRow(0); 
 // 合并单元格 
 CellRangeAddress region = new CellRangeAddress(0, 0, 0, (cols - 1)); 
 _sheet.AddMergedRegion(region); 
 // 填充值 
 _row.CreateCell(0).SetCellValue(model.tableTitle); 
 // 设置样式 
 _row.GetCell(0).CellStyle = myTitleStyle; 
 // 设置行高 
 _row.HeightInPoints = 20; 
 } 
 
 // 取得上一个实体 
 NPOIHeader lastRow = null; 
 IList<NPOIHeader> hList = GetHeaders(model.headerName, rows, model.isTitle); 
 // 创建表头 
 foreach (NPOIHeader m in hList) 
 { 
 var data = hList.Where(c => c.firstRow == m.firstRow && c.lastCol == m.firstCol - 1); 
 if (data.Count() > 0) 
 { 
 lastRow = data.First(); 
 if (m.headerName == lastRow.headerName) 
 m.firstCol = lastRow.firstCol; 
 } 
 
 // 获取行 
 _row = _sheet.GetRow(m.firstRow); 
 // 合并单元格 
 CellRangeAddress region = new CellRangeAddress(m.firstRow, m.lastRow, m.firstCol, m.lastCol); 
 
 _sheet.AddMergedRegion(region); 
 // 填充值 
 _row.CreateCell(m.firstCol).SetCellValue(m.headerName); 
 } 
 // 填充表头样式 
 for (int i = 0; i < rows + model.isTitle; i++) 
 { 
 _row = _sheet.GetRow(i); 
 for (int j = 0; j < cols; j++) 
 { 
 _row.GetCell(j).CellStyle = myBodyStyle; 
 //设置列宽 
 _sheet.SetColumnWidth(j, (model.colWidths[j] + 1) * 450); 
 } 
 } 
 
 rowIndex = (rows + model.isTitle); 
 } 
 
 #endregion 
 
 #region 填充内容 
 
 // 构建列 
 _row = _sheet.CreateRow(rowIndex); 
 foreach (DataColumn column in dt.Columns) 
 { 
 // 添加序号列 
 if (1 == model.isOrderby && column.Ordinal == 0) 
 { 
 _cell = _row.CreateCell(0); 
 _cell.SetCellValue(rowIndex - rows); 
 _cell.CellStyle = myBodyStyle; 
 } 
 
 // 创建列 
 _cell = _row.CreateCell(column.Ordinal + model.isOrderby); 
 
 // 获取值 
 drValue = row[column].ToString(); 
 
 switch (column.DataType.ToString()) 
 { 
 case "System.String"://字符串类型 
 _cell.SetCellValue(drValue); 
 _cell.CellStyle = myBodyStyle; 
 break; 
 case "System.DateTime"://日期类型 
 DateTime dateV; 
 DateTime.TryParse(drValue, out dateV); 
 _cell.SetCellValue(dateV); 
 
 _cell.CellStyle = myDateStyle;//格式化显示 
 break; 
 case "System.Boolean"://布尔型 
 bool boolV = false; 
 bool.TryParse(drValue, out boolV); 
 _cell.SetCellValue(boolV); 
 _cell.CellStyle = myBodyStyle; 
 break; 
 case "System.Int16"://整型 
 case "System.Int32": 
 case "System.Int64": 
 case "System.Byte": 
 int intV = 0; 
 int.TryParse(drValue, out intV); 
 _cell.SetCellValue(intV); 
 _cell.CellStyle = myBodyRightStyle; 
 break; 
 case "System.Decimal"://浮点型 
 case "System.Double": 
 double doubV = 0; 
 double.TryParse(drValue, out doubV); 
 _cell.SetCellValue(doubV.ToString("f2")); 
 _cell.CellStyle = myBodyRightStyle; 
 break; 
 case "System.DBNull"://空值处理 
 _cell.SetCellValue(""); 
 break; 
 default: 
 _cell.SetCellValue(""); 
 break; 
 } 
 
 } 
 
 #endregion 
 
 rowIndex++; 
 } 
 } 
 } 
 
 #region 辅助方法 
 
 /// <summary> 
 /// 表头解析 
 /// </summary> 
 /// <remarks> 
 /// </remarks> 
 /// <param name="header">表头</param> 
 /// <param name="rows">总行数</param> 
 /// <param name="addRows">外加行</param> 
 /// <param name="addCols">外加列</param> 
 /// <returns></returns> 
 private static IList<NPOIHeader> GetHeaders(string header, int rows, int addRows) 
 { 
 // 临时表头数组 
 string[] tempHeader; 
 string[] tempHeader2; 
 // 所跨列数 
 int colSpan = 0; 
 // 所跨行数 
 int rowSpan = 0; 
 // 单元格对象 
 NPOIHeader model = null; 
 // 行数计数器 
 int rowIndex = 0; 
 // 列数计数器 
 int colIndex = 0; 
 // 
 IList<NPOIHeader> list = new List<NPOIHeader>(); 
 // 初步解析 
 string[] headers = header.Split(new string[] { "#" }, StringSplitOptions.RemoveEmptyEntries); 
 // 表头遍历 
 for (int i = 0; i < headers.Length; i++) 
 { 
 // 行数计数器清零 
 rowIndex = 0; 
 // 列数计数器清零 
 colIndex = 0; 
 // 获取所跨行数 
 rowSpan = GetRowSpan(headers[i], rows); 
 // 获取所跨列数 
 colSpan = GetColSpan(headers[i]); 
 
 // 如果所跨行数与总行数相等,则不考虑是否合并单元格问题 
 if (rows == rowSpan) 
 { 
 colIndex = GetMaxCol(list); 
 model = new NPOIHeader(headers[i], 
 addRows, 
 (rowSpan - 1 + addRows), 
 colIndex, 
 (colSpan - 1 + colIndex), 
 addRows); 
 list.Add(model); 
 rowIndex += (rowSpan - 1) + addRows; 
 } 
 else 
 { 
 // 列索引 
 colIndex = GetMaxCol(list); 
 // 如果所跨行数不相等,则考虑是否包含多行 
 tempHeader = headers[i].Split(new string[] { " " }, StringSplitOptions.RemoveEmptyEntries); 
 for (int j = 0; j < tempHeader.Length; j++) 
 { 
 
 // 如果总行数=数组长度 
 if (1 == GetColSpan(tempHeader[j])) 
 { 
 if (j == tempHeader.Length - 1 && tempHeader.Length < rows) 
 { 
 model = new NPOIHeader(tempHeader[j], 
 (j + addRows), 
 (j + addRows) + (rows - tempHeader.Length), 
 colIndex, 
 (colIndex + colSpan - 1), 
 addRows); 
 list.Add(model); 
 } 
 else 
 { 
 model = new NPOIHeader(tempHeader[j], 
 (j + addRows), 
 (j + addRows), 
 colIndex, 
 (colIndex + colSpan - 1), 
 addRows); 
 list.Add(model); 
 } 
 } 
 else 
 { 
 // 如果所跨列数不相等,则考虑是否包含多列 
 tempHeader2 = tempHeader[j].Split(new string[] { "," }, StringSplitOptions.RemoveEmptyEntries); 
 for (int m = 0; m < tempHeader2.Length; m++) 
 { 
 // 列索引 
 colIndex = GetMaxCol(list) - colSpan + m; 
 if (j == tempHeader.Length - 1 && tempHeader.Length < rows) 
 { 
 model = new NPOIHeader(tempHeader2[m], 
 (j + addRows), 
 (j + addRows) + (rows - tempHeader.Length), 
 colIndex, 
 colIndex, 
 addRows); 
 list.Add(model); 
 } 
 else 
 { 
 model = new NPOIHeader(tempHeader2[m], 
 (j + addRows), 
 (j + addRows), 
 colIndex, 
 colIndex, 
 addRows); 
 list.Add(model); 
 } 
 } 
 } 
 rowIndex += j + addRows; 
 } 
 } 
 } 
 return list; 
 } 
 
 /// <summary> 
 /// 获取最大列 
 /// </summary> 
 /// <param name="list"></param> 
 /// <returns></returns> 
 private static int GetMaxCol(IList<NPOIHeader> list) 
 { 
 int maxCol = 0; 
 if (list.Count > 0) 
 { 
 foreach (NPOIHeader model in list) 
 { 
 if (maxCol < model.lastCol) 
 maxCol = model.lastCol; 
 } 
 maxCol += 1; 
 } 
 
 return maxCol; 
 } 
 
 /// <summary> 
 /// 获取表头行数 
 /// </summary> 
 /// <param name="newHeaders">表头文字</param> 
 /// <returns></returns> 
 private static int GetRowCount(string newHeaders) 
 { 
 string[] ColumnNames = newHeaders.Split(new char[] { '@' }); 
 int Count = 0; 
 if (ColumnNames.Length <= 1) 
 ColumnNames = newHeaders.Split(new char[] { '#' }); 
 foreach (string name in ColumnNames) 
 { 
 int TempCount = name.Split(new char[] { ' ' }).Length; 
 if (TempCount > Count) 
 Count = TempCount; 
 } 
 return Count; 
 } 
 
 /// <summary> 
 /// 获取表头列数 
 /// </summary> 
 /// <param name="newHeaders">表头文字</param> 
 /// <returns></returns> 
 private static int GetColCount(string newHeaders) 
 { 
 string[] ColumnNames = newHeaders.Split(new char[] { '@' }); 
 int Count = 0; 
 if (ColumnNames.Length <= 1) 
 ColumnNames = newHeaders.Split(new char[] { '#' }); 
 Count = ColumnNames.Length; 
 foreach (string name in ColumnNames) 
 { 
 int TempCount = name.Split(new char[] { ',' }).Length; 
 if (TempCount > 1) 
 Count += TempCount - 1; 
 } 
 return Count; 
 } 
 
 /// <summary> 
 /// 列头跨列数 
 /// </summary> 
 /// <remarks> 
 /// </remarks> 
 /// <param name="newHeaders">表头文字</param> 
 /// <returns></returns> 
 private static int GetColSpan(string newHeaders) 
 { 
 return newHeaders.Split(',').Count(); 
 } 
 
 /// <summary> 
 /// 列头跨行数 
 /// </summary> 
 /// <remarks> 
 /// </remarks> 
 /// <param name="newHeaders">列头文本</param> 
 /// <param name="rows">表头总行数</param> 
 /// <returns></returns> 
 private static int GetRowSpan(string newHeaders, int rows) 
 { 
 int Count = newHeaders.Split(new string[] { " " }, StringSplitOptions.RemoveEmptyEntries).Length; 
 // 如果总行数与当前表头所拥有行数相等 
 if (rows == Count) 
 Count = 1; 
 else if (Count < rows) 
 Count = 1 + (rows - Count); 
 else 
 throw new Exception("表头格式不正确!"); 
 return Count; 
 } 
 
 #endregion 
 
 #region 单元格样式 
 
 /// <summary> 
 /// 数据单元格样式 
 /// </summary> 
 private static ICellStyle bodyStyle 
 { 
 get 
 { 
 ICellStyle style = _workbook.CreateCellStyle(); 
 style.Alignment = HorizontalAlignment.CENTER; //居中 
 style.VerticalAlignment = VerticalAlignment.CENTER;//垂直居中 
 style.WrapText = true;//自动换行 
 // 边框 
 style.BorderBottom = BorderStyle.THIN; 
 style.BorderLeft = BorderStyle.THIN; 
 style.BorderRight = BorderStyle.THIN; 
 style.BorderTop = BorderStyle.THIN; 
 // 字体 
 //IFont font = _workbook.CreateFont(); 
 //font.FontHeightInPoints = 10; 
 //font.FontName = "宋体"; 
 //style.SetFont(font); 
 
 return style; 
 } 
 } 
 
 /// <summary> 
 /// 数据单元格样式 
 /// </summary> 
 private static ICellStyle bodyRightStyle 
 { 
 get 
 { 
 ICellStyle style = _workbook.CreateCellStyle(); 
 style.Alignment = HorizontalAlignment.RIGHT; //居中 
 style.VerticalAlignment = VerticalAlignment.CENTER;//垂直居中 
 style.WrapText = true;//自动换行 
 // 边框 
 style.BorderBottom = BorderStyle.THIN; 
 style.BorderLeft = BorderStyle.THIN; 
 style.BorderRight = BorderStyle.THIN; 
 style.BorderTop = BorderStyle.THIN; 
 // 字体 
 //IFont font = _workbook.CreateFont(); 
 //font.FontHeightInPoints = 10; 
 //font.FontName = "宋体"; 
 //style.SetFont(font); 
 
 return style; 
 } 
 } 
 
 /// <summary> 
 /// 标题单元格样式 
 /// </summary> 
 private static ICellStyle titleStyle 
 { 
 get 
 { 
 ICellStyle style = _workbook.CreateCellStyle(); 
 style.Alignment = HorizontalAlignment.CENTER; //居中 
 style.VerticalAlignment = VerticalAlignment.CENTER;//垂直居中 
 style.WrapText = true;//自动换行 
 
 //IFont font = _workbook.CreateFont(); 
 //font.FontHeightInPoints = 14; 
 //font.FontName = "宋体"; 
 //font.Boldweight = (short)FontBoldWeight.BOLD; 
 //style.SetFont(font); 
 
 return style; 
 } 
 } 
 
 /// <summary> 
 /// 日期单元格样式 
 /// </summary> 
 private static ICellStyle dateStyle 
 { 
 get 
 { 
 ICellStyle style = _workbook.CreateCellStyle(); 
 style.Alignment = HorizontalAlignment.CENTER; //居中 
 style.VerticalAlignment = VerticalAlignment.CENTER;//垂直居中 
 style.WrapText = true;//自动换行 
 // 边框 
 style.BorderBottom = BorderStyle.THIN; 
 style.BorderLeft = BorderStyle.THIN; 
 style.BorderRight = BorderStyle.THIN; 
 style.BorderTop = BorderStyle.THIN; 
 // 字体 
 //IFont font = _workbook.CreateFont(); 
 //font.FontHeightInPoints = 10; 
 //font.FontName = "宋体"; 
 //style.SetFont(font); 
 
 IDataFormat format = _workbook.CreateDataFormat(); 
 style.DataFormat = format.GetFormat("yyyy-MM-dd"); 
 return style; 
 } 
 } 
 
 #endregion 
 
 #endregion 
 } 
 
 /// <summary> 
 /// 实体类 
 /// </summary> 
 public class NPOIModel 
 { 
 /// <summary> 
 /// 数据源 
 /// </summary> 
 public DataTable dataSource { get; private set; } 
 /// <summary> 
 /// 要导出的数据列数组 
 /// </summary> 
 public string[] fileds { get; private set; } 
 /// <summary> 
 /// 工作薄名称数组 
 /// </summary> 
 public string sheetName { get; private set; } 
 /// <summary> 
 /// 表标题 
 /// </summary> 
 public string tableTitle { get; private set; } 
 /// <summary> 
 /// 表标题是否存在 1:存在 0:不存在 
 /// </summary> 
 public int isTitle { get; private set; } 
 /// <summary> 
 /// 是否添加序号 
 /// </summary> 
 public int isOrderby { get; private set; } 
 /// <summary> 
 /// 表头 
 /// </summary> 
 public string headerName { get; private set; } 
 /// <summary> 
 /// 取得列宽 
 /// </summary> 
 public int[] colWidths { get; private set; } 
 /// <summary> 
 /// 构造函数 
 /// </summary> 
 /// <remarks> 
 /// </remarks> 
 /// <param name="dataSource">数据来源 DataTable</param> 
 /// <param name="filed">要导出的字段,如果为空或NULL,则默认全部</param> 
 /// <param name="sheetName">工作薄名称</param> 
 /// <param name="headerName">表头名称 如果为空或NULL,则默认数据列字段 
 /// 相邻父列头之间用'#'分隔,父列头与子列头用空格(' ')分隔,相邻子列头用逗号分隔(',') 
 /// 两行:序号#分公司#组别#本日成功签约单数 预警,续约,流失,合计#累计成功签约单数 预警,续约,流失,合计#任务数#完成比例#排名 
 /// 三行:等级#级别#上期结存 件数,重量,比例#本期调入 收购调入 件数,重量,比例#本期发出 车间投料 件数,重量,比例#本期发出 产品外销百分比 件数,重量,比例#平均值 
 /// 三行时请注意:列头要重复 
 /// </param> 
 /// <param name="tableTitle">表标题</param> 
 /// <param name="isOrderby">是否添加序号 0:不添加 1:添加</param> 
 public NPOIModel(DataTable dataSource, string filed, string sheetName, string headerName, string tableTitle = null, int isOrderby = 0) 
 { 
 if (!string.IsNullOrEmpty(filed)) 
 { 
 this.fileds = filed.ToUpper().Split(new string[] { ";" }, StringSplitOptions.RemoveEmptyEntries); 
 
 // 移除多余数据列 
 for (int i = dataSource.Columns.Count - 1; i >= 0; i--) 
 { 
 DataColumn dc = dataSource.Columns[i]; 
 if (!this.fileds.Contains(dataSource.Columns[i].Caption.ToUpper())) 
 { 
 dataSource.Columns.Remove(dataSource.Columns[i]); 
 } 
 } 
 
 // 列索引 
 int colIndex = 0; 
 // 循环排序 
 for (int i = 0; i < dataSource.Columns.Count; i++) 
 { 
 // 获取索引 
 colIndex = GetColIndex(dataSource.Columns[i].Caption.ToUpper()); 
 // 设置下标 
 dataSource.Columns[i].SetOrdinal(colIndex); 
 } 
 } 
 else 
 { 
 this.fileds = new string[dataSource.Columns.Count]; 
 for (int i = 0; i < dataSource.Columns.Count; i++) 
 { 
 this.fileds[i] = dataSource.Columns[i].ColumnName; 
 } 
 } 
 this.dataSource = dataSource; 
 
 if (!string.IsNullOrEmpty(sheetName)) 
 { 
 this.sheetName = sheetName; 
 } 
 if (!string.IsNullOrEmpty(headerName)) 
 { 
 this.headerName = headerName; 
 } 
 else 
 { 
 this.headerName = string.Join("#", this.fileds); 
 } 
 if (!string.IsNullOrEmpty(tableTitle)) 
 { 
 this.tableTitle = tableTitle; 
 this.isTitle = 1; 
 } 
 // 取得数据列宽 数据列宽可以和表头列宽比较,采取最长宽度 
 colWidths = new int[this.dataSource.Columns.Count]; 
 foreach (DataColumn item in this.dataSource.Columns) 
 { 
 colWidths[item.Ordinal] = Encoding.GetEncoding(936).GetBytes(item.ColumnName.ToString()).Length; 
 } 
 // 循环比较最大宽度 
 for (int i = 0; i < this.dataSource.Rows.Count; i++) 
 { 
 for (int j = 0; j < this.dataSource.Columns.Count; j++) 
 { 
 int intTemp = Encoding.GetEncoding(936).GetBytes(this.dataSource.Rows[i][j].ToString()).Length; 
 if (intTemp > colWidths[j]) 
 { 
 colWidths[j] = intTemp; 
 } 
 } 
 } 
 if (isOrderby > 0) 
 { 
 this.isOrderby = isOrderby; 
 this.headerName = "序号#" + this.headerName; 
 } 
 } 
 
 /// <summary> 
 /// 获取列名下标 
 /// </summary> 
 /// <param name="colName">列名称</param> 
 /// <returns></returns> 
 private int GetColIndex(string colName) 
 { 
 for (int i = 0; i < this.fileds.Length; i++) 
 { 
 if (colName == this.fileds[i]) 
 return i; 
 } 
 return 0; 
 } 
 } 
 
 /// <summary> 
 /// 表头构建类 
 /// </summary> 
 public class NPOIHeader 
 { 
 /// <summary> 
 /// 表头 
 /// </summary> 
 public string headerName { get; set; } 
 /// <summary> 
 /// 起始行 
 /// </summary> 
 public int firstRow { get; set; } 
 /// <summary> 
 /// 结束行 
 /// </summary> 
 public int lastRow { get; set; } 
 /// <summary> 
 /// 起始列 
 /// </summary> 
 public int firstCol { get; set; } 
 /// <summary> 
 /// 结束列 
 /// </summary> 
 public int lastCol { get; set; } 
 /// <summary> 
 /// 是否跨行 
 /// </summary> 
 public int isRowSpan { get; private set; } 
 /// <summary> 
 /// 是否跨列 
 /// </summary> 
 public int isColSpan { get; private set; } 
 /// <summary> 
 /// 外加行 
 /// </summary> 
 public int rows { get; set; } 
 
 public NPOIHeader() { } 
 /// <summary> 
 /// 构造函数 
 /// </summary> 
 /// <param name="headerName">表头</param> 
 /// <param name="firstRow">起始行</param> 
 /// <param name="lastRow">结束行</param> 
 /// <param name="firstCol">起始列</param> 
 /// <param name="lastCol">结束列</param> 
 /// <param name="rows">外加行</param> 
 /// <param name="cols">外加列</param> 
 public NPOIHeader(string headerName, int firstRow, int lastRow, int firstCol, int lastCol, int rows = 0) 
 { 
 this.headerName = headerName; 
 this.firstRow = firstRow; 
 this.lastRow = lastRow; 
 this.firstCol = firstCol; 
 this.lastCol = lastCol; 
 // 是否跨行判断 
 if (firstRow != lastRow) 
 isRowSpan = 1; 
 if (firstCol != lastCol) 
 isColSpan = 1; 
 
 this.rows = rows; 
 } 
 } 
} 

3、导出代码示例如下:

/// <summary> 
/// 导出测点列表表格 
/// </summary> 
[HttpGet] 
[AllowAnonymous] 
public void ExportMeasurePointData(string TreeID, string TreeType) 
{ 
 DataTable dtResult = new DataTable(); 
 DataTable dtExcel = new DataTable(); 
 try 
 { 
 string sql = string.Format("EXEC P_GET_ZXJG_TagList '{0}','{1}'", TreeID, TreeType); 
 dtResult = QuerySQL.GetDataTable(sql); 
 dtExcel = dtResult.Copy(); 
 dtExcel.Columns.Add("xuhao", typeof(string)); 
 dtExcel.Columns.Add("StrValueTime", typeof(string)); 
 dtExcel.Columns["xuhao"].SetOrdinal(0); 
 dtExcel.Columns["StrValueTime"].SetOrdinal(2); 
 for (int i = 0; i < dtResult.Rows.Count; i++) 
 { 
 dtExcel.Rows[i]["xuhao"] = (i + 1).ToString(); 
 dtExcel.Rows[i]["StrValueTime"] = Convert.ToDateTime(dtResult.Rows[i]["F_ValueTime"]).ToString("yyyy-MM-dd HH:mm:ss"); 
 } 
 List<NPOIModel> list = new List<NPOIModel>(); 
 list.Add(new NPOIModel(dtExcel, "xuhao;F_Description;StrValueTime;F_Value;F_Unit;F_AlmLow;F_AlmUp", "sheet", "序号#监测点#采集时间#当前数值#工程单位#报警下限#报警上限")); 
 ATNPOIHelper.Export("测点列表", list, 0); 
 } 
 catch (Exception ex) 
 { 
 
 } 
} 

文档

asp.net 利用NPOI导出Excel通用类的方法

asp.net 利用NPOI导出Excel通用类的方法:解决中文文件名保存Excel乱码问题,主要是判断火狐或者IE浏览器,然后做对应的判断处理,核心代码如下: System.Web.HttpContext.Current.Response.ContentType = application/vnd.ms-excel; //设置下载的Excel文件名\ if (
推荐度:
标签: 导出 excel net
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top