导出数据

导出思路:
第一步:引用NPOI插件到项目中
第二步:筛选导出数据(表格数据查询)
第三步:获取工作簿、工作表、
第四步:构建表头(这里表头需要人为构建)导出数据
第五步:保存导出的Excel文件。 (使用IO流)
导出分两种
(1) 在已有的模板上导出数据;(前提: 必须要提前构建好模板)
(2) 直接导出数据。
bootstrap 框架样式表

后台模板中的字体图标css样式 系统维护样式表 表格的初始化 table的ID HTML元素的ID数据接口方法的路径 --由于需要进行条件查询,这里不用指定 多条件查询,先初始化空数据 判断是否选择时间段 if (!string.IsNullOrEmpty(startEndDate)) { startEndDate = startEndDate.Replace(" - ", "~"); string[] strs = startEndDate.Split('~');//根据 " - "分割字符串 if (strs.Length == 2) { DateTime dtStart = Convert.ToDateTime(strs[0]); DateTime dtEnd = Convert.ToDateTime(strs[1]); query = query.Where(o => o.payTime >= dtStart && o.payTime <= dtEnd); } } 使用读取模板的方式导出数据 根据模板文件的Excel导出 ==1-检查模板文件是否存在 // Server.MapPath 将相对的路径转为实际的物理路径 string templatePath = Server.MapPath("~/Document/ARDataTemplate.xls"); //判断模板是否存在 if (!System.IO.File.Exists(templatePath)) { //如果不存在,就返回失败信息 return Content("导出失败,请联系网站管理员"); } ==2-使用NPOI打开模板Excel =2.1-使用文件打开模板文件 FileStream templateStream = System.IO.File.Open(templatePath, FileMode.Open); //=2.2-使用NPOI打开模板Excel 得到一个工作簿 NPOI.HSSF.UserModel.HSSFWorkbook excelBookTemplate = new NPOI.HSSF.UserModel.HSSFWorkbook(templateStream); ==3-打开模板所在第一个工作表 NPOI.SS.UserModel.ISheet sheet = excelBookTemplate.GetSheetAt(0); //构建单元格样式 NPOI.SS.UserModel.ICellStyle style = excelBookTemplate.CreateCellStyle(); ==4-设置标题,如果筛选时间段不为空就拼接上筛选时间段 if (!string.IsNullOrEmpty(startEndDate)) { //提取模板标题 NPOI.SS.UserModel.IRow rowTitle = sheet.GetRow(0); rowTitle.GetCell(0).SetCellValue("订单查询 " + startEndDate); } ==5-往模板中填充数据 =5.1-设置数据单元格的样式 水平垂直居中对齐 style.Alignment = NPOI.SS.UserModel.HorizontalAlignment.Center; style.VerticalAlignment = NPOI.SS.UserModel.VerticalAlignment.Center; 设置边框为实线 style.BorderLeft = NPOI.SS.UserModel.BorderStyle.Thin; style.BorderTop = NPOI.SS.UserModel.BorderStyle.Thin; style.BorderRight = NPOI.SS.UserModel.BorderStyle.Thin; style.BorderBottom = NPOI.SS.UserModel.BorderStyle.Thin; ==5.2-开始填充数据 int index = 2;//目前这个模板数据开始填充数据的行索引为2 遍历查询出的数据 填充Excel单元格 for(int i = 0; i < list.Count(); i++) { NPOI.SS.UserModel.IRow row = sheet.CreateRow(index); ;//给sheet添加一行 row.Height = 22 * 20;//设置行高 //设置单元格数据 row.CreateCell(0).SetCellValue(i + 1); row.CreateCell(1).SetCellValue(list[i].orderNo); row.CreateCell(2).SetCellValue(list[i].payTime.ToString()); row.CreateCell(3).SetCellValue(list[i].totalPrice.ToString()); row.CreateCell(4).SetCellValue(list[i].agencyFee.ToString()); row.CreateCell(5).SetCellValue(list[i].payMoney.ToString()); row.CreateCell(6).SetCellValue(list[i].userGroup.ToString()); row.CreateCell(7).SetCellValue(list[i].jobNumber.ToString()); row.CreateCell(8).SetCellValue(list[i].PNR.ToString()); //设置单元格样式 for(int j = 0; j < row.Cells.Count; j++) { row.GetCell(j).CellStyle = style; } index++; } 导出Excel function exportExcel() { var startEndDate = $("#startEndDate").val(); window.open('@Url.Content("~/OthersMaintenance/ExportARdata/ExportARData?startEndDate=")' + startEndDate); }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值