在做MVC的项目中,常常会有涉及对很多数据的操作,而经常做的就是导入和导出了,我们先来了解一下导入导出。
导出:就是将你页面查询的数据导出到Excel表格,当然还有导出其他文件。
导入:就是将你需要添加的数据导入到数据库。
在一个项目中对数据的操作导入和导出肯定是需要掌握的,下面要讲的是如何导入导出Excel表格的数据,去控制器怎样写方法。
一、导入
1、需要导入数据,那肯定要先有一个模板,而模板一般也是准备好的,我们只需要写一个如何如何下载模板的方法就可以了。如下图所示看代码:
public ActionResult DowntTemplate(HttpPostedFileBase file) { //模板文件的路径 string filePath = Server.MapPath("~/Document/Template/考生信息导入模板.xls"); if (System.IO.File.Exists(filePath)) { string strfileName = Path.GetFileName(filePath);//获取文件名称 return File(new FileStream(filePath, FileMode.Open), "application/octet-stream", strfileName); } else { return Content("模板文件找不到!请检查文件是否存在!");//提示用户 } } |
上图代码只是在控制器写完了方法,下面再去到视图调用方法就可以完成下载模板了。只需要通过一个 window.open() 的方法就可以了。
2、模板下载好之后,那就是将模板上传了,竟然是上传文件,又会涉及到一些的判断,当判断都正确的时候,才能完成文件上传。
我们先来了解一下思路如下:
第一步:判断文件类型是否是 .xls;判断正确后再执行下面操作:
1、获取上传的文件,2、将文件转换为二进制数组
3、再将二进制数组转为为内存流,4、最后利用NPOI将内存流的数据读取到Excel工作簿
第二步:判断工作簿中是否有工作表;
第三步:判断工作表中是否有数据;
第四步:获取数据,保证数据的准确性;
第五步:最后将数据保存了。
下面看代码:
//判断工作表是否有数据 if (sheet.PhysicalNumberOfRows > 0) { //获取数据,保证数据准确性 DataTable dbExcel = new DataTable(); //实例化一个数据表 NPOI.SS.UserModel.IRow rowHeader = sheet.GetRow(1);//获取标题行(第二行索引为1,第一行是说明) int cellCount = rowHeader.LastCellNum; //获取表格列数 int rowCount = sheet.LastRowNum + 1;//获取表格行数 //创建dataTable中的列,循环添加标题行中各个单元格的值 for (int i = rowHeader.FirstCellNum; i < cellCount; i++) { DataColumn dtColumn = new DataColumn(rowHeader.GetCell(i).StringCellValue); dbExcel.Columns.Add(dtColumn); } |
public ActionResult TransportExcel(HttpPostedFileBase file) { string str = "";//定义一个字符串用来提示用户 try { Session.Remove("TransportExcel");//清除session,避免残留数据 string fileExtension = Path.GetExtension(file.FileName);//获取文件名后缀 //判断文件类型 if(".xls".Equals(fileExtension) || ".XLS".Equals(fileExtension)) { byte[] fileBytes = new byte[file.ContentLength];//声明二进制数组存放文件 file.InputStream.Read(fileBytes, 0, file.ContentLength);//将传入的文件转化为二进制的数组存入 MemoryStream excelFileStream = new MemoryStream(fileBytes);//将二进制数组转化为内存流 NPOI.SS.UserModel.IWorkbook workbook = new HSSFWorkbook(excelFileStream);//将内存流转化为工作簿 //判断工作簿中是否有工作表 if (workbook.NumberOfSheets > 0) { //查询出要导入的数据信息 List<SYS_Academe> listAcademe = (from tbAcademe in myModel.SYS_Academe select tbAcademe).ToList(); List<Student> listStudent = new List<Student>();//对象列表 NPOI.SS.UserModel.ISheet sheet = workbook.GetSheetAt(0);//获取第一个工作表 |
//读取Excel中的数据 for (int i = (sheet.FirstRowNum) + 2; i < rowCount; i++) { NPOI.SS.UserModel.IRow row = sheet.GetRow(i); //获取行的数据 DataRow dtRow = dbExcel.NewRow();//创建行 if (row != null) { //遍历excel中一行的所有单元格 for (int j = row.FirstCellNum; j < cellCount; j++) { if (row.GetCell(j) != null) { dtRow[j] = row.GetCell(j).ToString(); } } } dbExcel.Rows.Add(dtRow);//执行添加 } //遍历datatable中的数据 foreach (DataRow row in dbExcel.Rows) { //创建studentVo对象保存每一条数据 Student = new Student(); try { //获取其他数据(代码省略) } catch (Exception ) { str = "数据处理出错"; } } Session["ImportExcel"] = listStudent; //把数据保存到Session当中 str = "上传成功!"; } |
3、完成上面代码之后,模板中的数据也就上传成功了。下面就是将数据保存到数据库了,也就是执行批量新增。
第一步:将保存在Session中的数据获取到,在进行判断;
第二步:判断数据是否为空;第三步:判断数据是否重复;
第四步:执行新增,再保存
public ActionResult SaveInsert() { string str = ""; try { List<Student> studentVos = new List<Student>(); if (Session["ImportExcel"] != null) { studentVos = Session["ImportExcel"] as List<Student>; } //继续写新增代码... } catch (Exception) { str = "数据异常!"; } return Json(str, JsonRequestBehavior.AllowGet); } |
到这里导入的代码就完成了,最后再到视图写一个方法请求就可以了,就能完成导入数据了。
二、导出 (1)将要导出的数据查询出来;(2)引用NPOI插件创建表格,最后输出数据。
public ActionResult ExportExcel() { var listStudent = (//在这里写查询代码...); List<Student> listExaminee = listStudent.ToList();//将查询出来的数据转化为对象列表的格式 HSSFWorkbook excelBook = new HSSFWorkbook(); //创建工作簿Excel NPOI.SS.UserModel.ISheet sheet1 = excelBook.CreateSheet("考生信息");//为工作簿创建工作表并命名 //编写工作表 (1)表头 (2)数据:listStudent NPOI.SS.UserModel.IRow row1 = sheet1.CreateRow(0);//创建第一行 row1.CreateCell(0).SetCellValue("学号"); //创建其他列并赋值( 根据具体数据写代码...) for (int i = 0; i < listStudent.Count(); i++) { //创建行( 根据具体数据写代码...) NPOI.SS.UserModel.IRow rowTemp = sheet1.CreateRow(i + 1); rowTemp.CreateCell(0).SetCellValue(listExaminee[i].StudentNumber); } var fileName = "考生信息" + DateTime.Now.ToString("yyyy-MM-dd-HH-mm-ss-ffff") + ".xls";//文件名 //将Excel表格转化为流,输出 MemoryStream bookStream = new MemoryStream();//创建文件流 excelBook.Write(bookStream); //文件写入流(向流中写入字节序列) bookStream.Seek(0, SeekOrigin.Begin);//输出之前调用Seek,把0位置指定为开始位置 return File(bookStream, "application/vnd.ms-excel", fileName);//最后以文件形式返回 } |
写完方法之后再到视图请求调用方法就可以了,数据导出也就完成了。