ASP.NET MVC 导入、导出Excel方法

 

~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

开发工具和关键技术:Visual Studio 2015,ASP.NET MVC

作者:金建勇

撰写时间:2019年5月1日

~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

在做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);//最后以文件形式返回

}

写完方法之后再到视图请求调用方法就可以了,数据导出也就完成了。

你可能感兴趣的:(知识点)