导出的excel的是一个项目的基本功能 所以不多说 我们项目用的npoi 可以直接在vs的NuGet里面直接搜索下载 安装就可以用了
//创建一个excel HSSFWorkbook hwb = new HSSFWorkbook(); //创建一个excel中的表格 HSSFSheet sheet = (HSSFSheet)hwb.CreateSheet("sheet1"); //创建一个公司的title HSSFRow headerrow = (HSSFRow)sheet.CreateRow(0); headerrow.Height = 650; HSSFCell headercell = (HSSFCell)headerrow.CreateCell(0); headercell.SetCellValue("xxx有限公司"); //创建一个单元格样式 HSSFCellStyle cs = (HSSFCellStyle)hwb.CreateCellStyle(); //垂直居中 cs.VerticalAlignment = NPOI.SS.UserModel.VerticalAlignment.Center; //水平居中 cs.Alignment = NPOI.SS.UserModel.HorizontalAlignment.Center; //设置\n自动换行 cs.WrapText = true; //给单元格设置样式 headercell.CellStyle = cs; HSSFFont hf = (HSSFFont)hwb.CreateFont(); hf.Boldweight = 900;//设置字体加粗 hf.FontHeight = 260;//字体的高度 hf.Color = HSSFColor.Blue.Index;//设置字体颜色 cs.SetFont(hf); //合并单元格 sheet.AddMergedRegion(new CellRangeAddress(0, 0, 0, 46)); //创建行下面的列
这部分代码只是在创建excel 以及设置excel的样式 还没有进行导入
List<PowerRate> lit = new List<PowerRate>(); lit = _powerrate.GetPowerRateAll();//数据源 导出的数据 HSSFRow row1 = (HSSFRow)sheet.CreateRow(1); //表示从第几行开始写入
接下来就是创建表头
//创建表头
HSSFRow row1 = (HSSFRow)sheet.CreateRow(1); //创建行下面的列 row1.CreateCell(0).SetCellValue("xx"); row1.CreateCell(1).SetCellValue("xxx"); row1.CreateCell(2).SetCellValue("xxx"); row1.CreateCell(3).SetCellValue("xxx");
接着写入内容
for (int i = 0; i < lit.Count; i++) { //创建行 HSSFRow row = (HSSFRow)sheet.CreateRow(i + 2); // i+2 表示从第二行开始写入数据 第一行是表头 //创建行下面的列 row.CreateCell(0).SetCellValue(lit[i].City); row.CreateCell(1).SetCellValue(lit[i].County); row.CreateCell(2).SetCellValue(lit[i].StatiocCode); row.CreateCell(3).SetCellValue(lit[i].StationName); }
接着就是写入流 然后在浏览器端生成一个excel
MemoryStream ms = new MemoryStream(); string filename = DateTime.Now.ToString("yyyyMMddHHmmss"); hwb.Write(ms); ms.Seek(0, SeekOrigin.Begin);
我用的asp.net MVC 那么控制器的类型应该是 FileResult 返回的是return File(ms, "application/vnd.ms-excel", filename + ".xls");
然后在浏览器就可以生成一个你需要的excel了 由于本人还是个菜鸟 所以只知道怎么用 后续的具体原理还在研究