·您现在的位置: 云翼网络 >> 文章中心 >> 网站建设 >> 网站建设开发 >> ASP.NET网站开发 >> asp.net使用MVC4框架基于NPOI做导出数据到Excel表

asp.net使用MVC4框架基于NPOI做导出数据到Excel表

作者:佚名      ASP.NET网站开发编辑:admin      更新时间:2022-07-23

asp.net使用MVC4框架基于NPOI做导出数据到Excel表

NPOI 是POI项目的 .NET 版本。POI是一个开源的java读写Excel、Word等微软OLE2组件文档的项目。

使用 NPOI 你就可以在没有安装 Office 或者相应环境的机器上对 WORD/EXCEL 文档进行读写。NPOI是构建在POI 3.x版本之上的,它可以在没有安装Office的情况下对Word/Excel文档进行读写操作。使用 NPOI 你就可以在没有安装 Office 或者相应环境的机器上对 WORD/EXCEL 文档进行读写。NPOI是构建在POI 3.x版本之上的,它可以在没有安装Office的情况下对Word/Excel文档进行读写操作。

下面我们使用NPOI在MVC4框架下制作一个导出的功能。

(1)在DAL数据访问层,定义需要需要导出的数据表,可以根据需要导出的字段,进行SQL语句的组织条件。

 public DataTable GetData()        {            DataTable dt = new DataTable();            using (SqlConnection conn = new SqlConnection(ConfigurationManager.ConnectionStrings["connStr"].ToString()))            {                string sql = "select [LoginID],[WageID],[Name],[UserLimit],[OnDutyTime],[CarShiFa],[OnDutyDay],[NightOnDuty],[AllNightOnDuty],[CarAllowance],[WorkOvertime],[WeekendNightWork],[WeekendOverNight] from Kaoqinsum where OnDutyTime=datename(yy,getdate()) + '-' + datename(m,dateadd(m,-1,getdate()))";                conn.Open();                SqlCommand cmd = new SqlCommand(sql, conn);                SqlDataAdapter sda = new SqlDataAdapter(cmd);                sda.Fill(dt);                conn.Close();                return dt;            }        }

  (2)在BLL业务逻辑层,调用数据访问层中的GetDate();

  public DataTable GetDate()        {            return new SalaryManageDAL.KaoqinsumDAL().GetData();        }

  (3)在控制器中,我们来书写导出功能的主要代码。

  public ActionResult DaoChu()          {              DataTable dt = new SalaryManageBLL.KaoqinsumBLL().GetDate();              //1、实例化workbook工作簿对象              HSSFWorkbook hssfworkbook = new HSSFWorkbook();              //2、创建文档摘要信息              DocumentSummaryInformation dsf = PRopertySetFactory.CreateDocumentSummaryInformation();              dsf.Company = "沈阳工学院";//公司              dsf.Category = "Statistics";//类别              //CustomProperties 自定义属性              SummaryInformation si = PropertySetFactory.CreateSummaryInformation();              si.Author = "院办";//作者              //Comments 评论 CreateDateTime 创建时间 Template模板              si.Keywords = "kaoqin,yuanban";//关键字              si.Subject = "kaoqin";//主题              si.Title = "考勤汇总";//标题              si.RevNumber = "1.0";//版本号              //3、将写好的文档摘要 赋值workbook对象              hssfworkbook.DocumentSummaryInformation = dsf;              hssfworkbook.SummaryInformation = si;              //4、创建Sheet              HSSFSheet Sheet1 = (HSSFSheet)hssfworkbook.CreateSheet("Sheet1");              HSSFSheet Sheet2 = (HSSFSheet)hssfworkbook.CreateSheet("Sheet2");              HSSFSheet Sheet3 = (HSSFSheet)hssfworkbook.CreateSheet("Sheet3");              //5、创建页眉页脚              Sheet1.CreateRow(0).CreateCell(1).SetCellValue(123);              Sheet1.Header.Center = "统计数据";              Sheet1.Header.Left = "logo.png";              Sheet1.Header.Right = "zhguAddress";              Sheet1.Footer.Center = "page";              //6、标题              string yeartime = time();              HSSFCell fcell = (HSSFCell)Sheet1.CreateRow(0).CreateCell(0);//第一行              fcell.SetCellValue("沈阳工学院" + yeartime + "考勤汇总情况表");//文本              //合并单元格              Sheet1.AddMergedRegion(new CellRangeAddress(0, 0, 0, 13));//2.0使用 2.0以下为Region              //标题样式              HSSFCellStyle fCellStyle = (HSSFCellStyle)hssfworkbook.CreateCellStyle();              HSSFFont ffont = (HSSFFont)hssfworkbook.CreateFont();              ffont.FontHeight = 20 * 20;              ffont.FontName = "宋体";              ffont.Color = HSSFColor.BLUE.index;              fCellStyle.SetFont(ffont);              fCellStyle.VerticalAlignment = NPOI.SS.UserModel.VerticalAlignment.CENTER;//垂直对齐              fCellStyle.Alignment = NPOI.SS.UserModel.HorizontalAlignment.CENTER;//水平对齐              fcell.CellStyle = fCellStyle;              //7、设置单元格格式 创建单元格              /*模拟设定7列*/              HSSFDataFormat dataformat = (HSSFDataFormat)hssfworkbook.CreateDataFormat();//数据格式              HSSFFont font = (HSSFFont)hssfworkbook.CreateFont();//数据字体              font.Color = HSSFColor.BLACK.index; //颜色               font.IsItalic = false;//斜体              font.IsStrikeout = false;//加粗              font.FontName = "宋体";//字体              //必不可少 可以变更在循环输出数据时指定类型 需要调用sqlDbType 较复杂              //Id  int类型              HSSFCell cell1 = (HSSFCell)Sheet1.CreateRow(1).CreateCell(0); //创建单元格              HSSFCellStyle cellStyle1 = (HSSFCellStyle)hssfworkbook.CreateCellStyle();//单元格样式              cellStyle1.DataFormat = HSSFDataFormat.GetBuiltinFormat("");              // CellRangeAddressList ranglist1 = new CellRangeAddressList(0, 65535, 0, 0);//集合限定类型              // DVConstraint constraint1 = DVConstraint.CreateNumericConstraint(DVConstraint.ValidationType.INTEGER, DVConstraint.OperatorType.BETWEEN, "0", "100");//约束              cellStyle1.SetFont(font);              cell1.CellStyle = cellStyle1;              cell1.SetCellValue("");              //Name              HSSFCell cell2 = (HSSFCell)Sheet1.CreateRow(1).CreateCell(1);              HSSFCellStyle cellStyle2 = (HSSFCellStyle)hssfworkbook.CreateCellStyle();              cellStyle2.DataFormat = HSSFDataFormat.GetBuiltinFormat("");              cellStyle2.SetFont(font);              cell2.CellStyle = cellStyle2;              cell2.SetCellValue("");              //phone              HSSFCell cell3 = (HSSFCell)Sheet1.CreateRow(1).CreateCell(2);              HSSFCellStyle cellStyle3 = (HSSFCellStyle)hssfworkbook.CreateCellStyle();              cellStyle3.DataFormat = HSSFDataFormat.GetBuiltinFormat("");              cellStyle3.SetFont(font);              cell3.CellStyle = cellStyle3;              cell3.SetCellValue("");              //address              HSSFCell cell4 = (HSSFCell)Sheet1.CreateRow(1).CreateCell(3);              HSSFCellStyle cellStyle4 = (HSSFCellStyle)hssfworkbook.CreateCellStyle();              cellStyle4.DataFormat = HSSFDataFormat.GetBuiltinFormat("");              cellStyle4.SetFont(font);              cell4.CellStyle = cellStyle4;              cell4.SetCellValue("");              //Status              HSSFCell cell5 = (HSSFCell)Sheet1.CreateRow(1).CreateCell(4);              HSSFCellStyle cellStyle5 = (HSSFCellStyle)hssfworkbook.CreateCellStyle();              cellStyle5.DataFormat = HSSFDataFormat.GetBuiltinFormat("");              cellStyle5.SetFont(font);              cell5.CellStyle = cellStyle5;              cell5.SetCellValue("");              //balance              HSSFCell cell6 = (HSSFCell)Sheet1.CreateRow(1).CreateCell(5);              HSSFCellStyle cellStyle6 = (HSSFCellStyle)hssfworkbook.CreateCellStyle();              cell6.SetCellValue("");              cellStyle6.DataFormat = HSSFDataFormat.GetBuiltinFormat("");              cellStyle6.SetFont(font);              cell6.CellStyle = cellStyle6;              //CreateDate              HSSFCell cell7 = (HSSFCell)Sheet1.CreateRow(1).CreateCell(6);              HSSFCellStyle cellStyle7 = (HSSFCellStyle)hssfworkbook.CreateCellStyle();              cellStyle7.DataFormat = HSSFDataFormat.GetBuiltinFormat("");              cellStyle7.SetFont(font);              cell7.CellStyle = cellStyle7;              cell7.SetCellValue("");              HSSFCell cell8 = (HSSFCell)Sheet1.CreateRow(1).CreateCell(7);              HSSFCellStyle cellStyle8 = (HSSFCellStyle)hssfworkbook.CreateCellStyle();              cellStyle8.DataFormat = HSSFDataFormat.GetBuiltinFormat("");              cellStyle8.SetFont(font);              cell8.CellStyle = cellStyle8;              cell8.SetCellValue("");              HSSFCell cell9 = (HSSFCell)Sheet1.CreateRow(1).CreateCell(8);              HSSFCellStyle cellStyle9 = (HSSFCellStyle)hssfworkbook.CreateCellStyle();              cellStyle9.DataFormat = HSSFDataFormat.GetBuiltinFormat("");              cellStyle9.SetFont(font);              cell9.CellStyle = cellStyle9;              cell9.SetCellValue("");              HSSFCell cell10 = (HSSFCell)Sheet1.CreateRow(1).CreateCell(9);              HSSFCellStyle cellStyle10 = (HSSFCellStyle)hssfw