.net mvc NPOI模板导出数据到excel
/// <summary> /// 使用模板导出Excel /// </summary> /// <typeparam name="T"></typeparam> /// <param name="list">导出数据集</param> /// <param name="index">从模板中第几个输出数据</param> /// <param name="tempPath">模板存放路径</param> /// <param name="exportPath">导出文件存放路径</param> /// <returns></returns> public string TemplateOutput<T>(List<T> list, int index, string tempPath, string exportPath) { //创建目录 if (!Directory.Exists(exportPath)) Directory.CreateDirectory(exportPath); using (MemoryStream ms = new MemoryStream()) { string extension = Path.GetExtension(tempPath); FileStream fs = System.IO.File.OpenRead(tempPath); IWorkbook workbook = null; if (extension.Equals(".xls")) { workbook = new HSSFWorkbook(fs);//创建Excel工作簿 } else { workbook = new XSSFWorkbook(fs); } fs.Close(); ISheet sheet = workbook.GetSheetAt(0);//创建工作表 IRow rows = null; //循环数据写入excel for (int i = 0; i < list.Count; i++) { //rows = sheet.CreateRow(i + index - 1); rows = sheet.GetRow(i + index - 1); int j = 0; var Typed = typeof(T); System.Reflection.PropertyInfo[] properties = list[i].GetType().GetProperties(System.Reflection.BindingFlags.Instance | System.Reflection.BindingFlags.Public); foreach (System.Reflection.PropertyInfo item in properties) { string name = item.Name; object value = item.GetValue(list[i], null); if (item.PropertyType.IsValueType || item.PropertyType.Name.StartsWith("String")) { //rows.CreateCell(j).SetCellValue(value.ToString()); rows.GetCell(j).SetCellValue(value.ToString()); j++; } else { return "Error"; } } } workbook.Write(ms); var buf = ms.ToArray(); //保存为Excel文件 string fileName = ClassesLib.GetIdByTime() + extension; string downLoadPath = exportPath + fileName; using (FileStream fsTmp = new FileStream(downLoadPath, FileMode.Create, FileAccess.Write)) { fsTmp.Write(buf, 0, buf.Length); fsTmp.Flush(); fsTmp.Close(); } return fileName; } } //调用方法 try { string sYear = Convert.ToDateTime(genDate + "-01").Year.ToString(); string sMonth = Convert.ToDateTime(genDate + "-01").Month.ToString(); string sqlStr = "SELECT ID,COUNTY,PLANCOUNT,FINISHCOUNT,FINISHRATE,TOPPLANCOUNT,TOPFINISHCOUNT,TOPFINISHRATE,BSCOUNT,SSCOUNT,BKCOUNT,DPLANTCOUNT,DPLANTBSCOUNT,DPLANTSSCOUNT,DPLANTBKCOUNT FROM COUNTY_KEY_INDUSTRY_TOTAL WHERE SYEAR='" + sYear + "' AND SMONTH='" + sMonth + "'"; var list = db.Database.SqlQuery<KeyIndustryListView>(sqlStr).ToList();//获取总页数 //模板路径 string tempPath = System.Web.HttpContext.Current.Server.MapPath("~/Content/Template/exportTemp.xls"); string exportPath = Server.MapPath("/UploadFiles/DownloadFile/"); //保存路径 string fileName = TemplateOutput(list,6, tempPath, exportPath); return Redirect("/UploadFiles/DownloadFile/" + fileName); } catch (Exception e) { return Content(e.Message); }
猜您可能还喜欢
- asp.net mvc内微信pc端、H5、JsApi支付方式总结(5702)
- HTML5 WebSocket与C#建立Socket连接实现代码(2866)
- asp.net mvc开发移动端省、市、县三级地区选择控件实现方法(1700)
- C# 使用Socket链接Ftp服务器下载上传代码FTPClient(1634)
- VS 2017调试程序鼠标定位文本输入框浏览器闪退调试终止解决方法(1487)
- C# 两个类的实例之间相同属性的值的复制(1381)
- 关于“System.Data.OleDb.OleDbException,外部数据库驱动程序 (1) 中的意外错误。”的解决方案(1338)
- C#微信公众号推送消息接口消息排重(1175)
- html5 webScoket与C#建立Socket连接(1074)
- 什么是.NET Core ?它和.NET Framework 有什么不同?(1047)
评论列表
发表评论
文章分类
文章归档
- 2025年3月 (1)
- 2024年6月 (2)
- 2024年5月 (2)
- 2024年4月 (4)
- 2024年3月 (30)
- 2024年1月 (4)
- 2023年12月 (2)
- 2023年11月 (4)
- 2023年10月 (4)
- 2023年9月 (6)
- 2023年3月 (2)
- 2023年2月 (1)
- 2023年1月 (1)
- 2022年12月 (1)
- 2022年9月 (21)
- 2022年8月 (10)
- 2022年7月 (3)
- 2022年4月 (1)
- 2022年3月 (13)
- 2021年8月 (1)
- 2021年3月 (1)
- 2020年12月 (42)
- 2020年11月 (7)
- 2020年10月 (5)
- 2020年8月 (1)
- 2020年6月 (1)
- 2020年3月 (2)
- 2019年12月 (8)
- 2019年11月 (3)
- 2019年9月 (1)
- 2019年4月 (1)
- 2019年3月 (6)
- 2019年2月 (1)
- 2018年7月 (7)
阅读排行
- 1.asp.net mvc内微信pc端、H5、JsApi支付方式总结(5702)
- 2.各大搜索网站网站收录提交入口地址(3201)
- 3.Windows 10休眠文件更改存储位置(3166)
- 4.ECharts仪表盘实例及参数使用详解(3095)
- 5.windows 10安装myeclipse 10破解补丁cracker.jar、run.bat闪退解决办法(2993)
- 6.HTML5 WebSocket与C#建立Socket连接实现代码(2866)
- 7.华为鸿蒙系统清除微信浏览器缓存方法(2788)
- 8.CERT_HAS_EXPIRED错误如何解决(2252)
- 9.Js异步async、await关键字详细介绍(lambda表达式中使用async和await关键字)(2189)
- 10.HBuilder编辑器格式化代码(2119)