.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支付方式总结(5877)
- HTML5 WebSocket与C#建立Socket连接实现代码(3180)
- asp.net mvc开发移动端省、市、县三级地区选择控件实现方法(1796)
- C# 使用Socket链接Ftp服务器下载上传代码FTPClient(1718)
- C# 两个类的实例之间相同属性的值的复制(1578)
- 关于“System.Data.OleDb.OleDbException,外部数据库驱动程序 (1) 中的意外错误。”的解决方案(1574)
- VS 2017调试程序鼠标定位文本输入框浏览器闪退调试终止解决方法(1565)
- C#微信公众号推送消息接口消息排重(1247)
- html5 webScoket与C#建立Socket连接(1143)
- 什么是.NET Core ?它和.NET Framework 有什么不同?(1123)
评论列表
发表评论
文章分类
文章归档
- 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支付方式总结(5877)
- 2.Windows 10休眠文件更改存储位置(3832)
- 3.各大搜索网站网站收录提交入口地址(3480)
- 4.ECharts仪表盘实例及参数使用详解(3433)
- 5.windows 10安装myeclipse 10破解补丁cracker.jar、run.bat闪退解决办法(3423)
- 6.HTML5 WebSocket与C#建立Socket连接实现代码(3180)
- 7.华为鸿蒙系统清除微信浏览器缓存方法(3173)
- 8.CERT_HAS_EXPIRED错误如何解决(2967)
- 9.Js异步async、await关键字详细介绍(lambda表达式中使用async和await关键字)(2604)
- 10.HBuilder编辑器格式化代码(2394)
