前言:

记录这篇使用记录,是为了方便以后学习查阅和让没有使用过的人了解一下,其中不足还请见谅。不是很全的文章,大神请绕行。

在项目中我们或多或少的会遇到数据导出到excel表格以便线下查看或者记录一些需要的数据信息。我所知道的有两个EPPlus和NPIO这两个插件。

NPIO这个恕在下才疏学浅还没有使用不好多说,今天我就来说一下EPPlus。

EPPlus准备:

EPPlus官网地址:https://github.com/JanKallman/EPPlus

下载之后,我们在程序添加程序集之后在需要使用的地方添加一下引用:

using OfficeOpenXml;

using OfficeOpenXml.Style;

using System.Drawing;

这几个只是最基础的引用控件,你要使用更多当然需要增加更多命名空间比如图标,需要在增加using OfficeOpenXml.Drawing.Chart;

附上EPPlus支持功能列表:

好了废话不多说进入正题。

使用EPPlus:

1.创建存放文件夹

//创建存放Excel的文件夹

string path = Server.MapPath("~/Upload/Excel/MenuInfor/");

string fileName = DateTime.Now.ToString("yyyyMMddHHmmssffffff") + ".xlsx";

pathFileName = path + fileName;

  1. //如果上传目录不存在就创建
  2. if (!Directory.Exists(path))
  3. {
  4. Directory.CreateDirectory(path);
  5. }
  6. FileInfo newFile = new FileInfo(pathFileName);
  7. if (newFile.Exists)
  8. {
  9. newFile.Delete();
  10. newFile = new FileInfo(pathFileName);
  11. }

2.创建工作簿

有了存放位置之后就是创建真正的excel文件了,注意这里用到using哦,这是必须的哦。创建工作薄并存入上面所说的位置

using (ExcelPackage package = new ExcelPackage(newFile))

{

//这里面是excel所有的操作



3.创建Sheet表格

也就是我们所说的选项卡,这里才是我们存放数据的展现层。

ExcelWorksheet workSheet = package.Workbook.Worksheets.Add("这里是选项卡名称");

4.开始填充

#region 添加表头

/添加表头/

workSheet.InsertRow(1, 1);

using (var range = workSheet.Cells[1, 1, 1, 4])

{

range.Merge = true;

range.Style.Font.SetFromFont(new Font("Britannic Bold", 18, FontStyle.Regular));

range.Style.HorizontalAlignment = ExcelHorizontalAlignment.CenterContinuous;

range.Style.Fill.PatternType = ExcelFillStyle.Solid;

range.Style.Fill.BackgroundColor.SetColor(Color.FromArgb(184, 204, 228));

range.Style.Font.Color.SetColor(Color.Black);

range.Value = "菜单导出信息";

}

#endregion

region 设置列宽

  1. //设置列宽
  2. workSheet.Column(1).Width = 30;
  3. workSheet.Column(2).Width = 30;
  4. workSheet.Column(3).Width = 30;
  5. workSheet.Column(4).Width = 20;
  6. #endregion

region 设置标题

  1. /*设置标题*/
  2. workSheet.Cells[2, 1].Value = "菜名";
  3. workSheet.Cells[2, 2].Value = "材料名称";
  4. workSheet.Cells[2, 3].Value = "材料类别";
  5. workSheet.Cells[2, 4].Value = "材料所需克数";
  6. #endregion

using (var range = workSheet.Cells[2, 1, 2, 4])

{

range.Style.Font.Bold = true;

range.Style.Fill.PatternType = ExcelFillStyle.Solid;

range.Style.Border.BorderAround(ExcelBorderStyle.Thin, Color.FromArgb(70, 130, 180));

range.Style.Fill.BackgroundColor.SetColor(Color.FromArgb(70, 130, 180));

range.Style.Font.Color.SetColor(Color.White);

//range.AutoFilter = true;

}

region 设置单元格内容

  1. /*设置单元格内容*/
  2. int row = 3;
  3. foreach (FoodMenuInfor item in foodInforList)
  4. {
  5. var biginRow = row;
  6. var menuDataList = menuData.Where(u => u.menuId == item.id);
  7. //对名称进行查询
  8. if (!string.IsNullOrEmpty(stuffName))
  9. {
  10. menuDataList = menuDataList.Where(a => a.stuffName.Contains(stuffName));
  11. }
  12. //对类别进行查询
  13. if (!string.IsNullOrEmpty(stuffType))
  14. {
  15. menuDataList = menuDataList.Where(a => a.stuffType == stuffType);
  16. }
  17. menuDataList.OrderByDescending(b => b.addTime);
  18. foreach (var loop in menuDataList)
  19. {
  20. workSheet.Cells[row, 1].Value = "";
  21. workSheet.Cells[row, 2].Value = loop.stuffName;
  22. workSheet.Cells[row, 3].Value = loop.stuffType;
  23. workSheet.Cells[row, 4].Value = loop.requireNum;
  24. row++;
  25. }
  26. if (menuDataList.Count() == 0)
  27. {
  28. workSheet.Cells[row, 1].Value = "";
  29. workSheet.Cells[row, 2].Value = "";
  30. workSheet.Cells[row, 3].Value = "";
  31. workSheet.Cells[row, 4].Value = "";
  32. row++;
  33. }
  34. //合并园区行头
  35. workSheet.Cells[biginRow, 1, row - 1, 1].Merge = true;
  36. workSheet.Cells[biginRow, 1, row - 1, 1].Value = item.menuName;
  37. }
  38. #endregion

5.终于内容写完了

内容添加完了,我就稍微设置了下文字水平居中和垂直居中,最后进行保存

workSheet.Cells.Style.HorizontalAlignment = ExcelHorizontalAlignment.Center;//水平居中

workSheet.Cells.Style.VerticalAlignment = ExcelVerticalAlignment.Center;//垂直居中

package.Save();

最后上一下结果。

资料借鉴:

Wico's Blog大神: http://www.mamicode.com/info-detail-63790.html

下面是pengtan大神使用NPOI和EPPlus的对比:http://www.cnblogs.com/tanpeng/p/6155749.html

使用那个全凭自己喜好吧,对比自己了解就好。

导出excel记录的更多相关文章

  1. mvc导出excel记录

    前言: 记录这篇使用记录,是为了方便以后学习查阅和让没有使用过的人了解一下,其中不足还请见谅.不是很全的文章,大神请绕行.在项目中我们或多或少的会遇到数据导出到excel表格以便线下查看或者记录一些需 ...

  2. 记录一个 C# 导出 Excel 的坑

    Ø  简介 其实该文章并没有什么技术含量,只是记录下个人心得.在以后有朋友遇到类似问题,可以借鉴下,或者遇到相同问题时的提供个参考方向. 也算我的一个经历吧,这个问题我花了足足一天多的时间才找到问题, ...

  3. Oracle导出excel

    oracle导出excel(非csv)的方法有两种,1.使用sqlplus  spool,2.使用包体 现将网上相关代码整理后贴出以备不时之需: 使用sqlplus: 使用sqlplus需要两个文件: ...

  4. [转]Java中导入、导出Excel

    原文地址:http://blog.csdn.net/jerehedu/article/details/45195359 一.介绍 当前B/S模式已成为应用开发的主流,而在企业办公系统中,常常有客户这样 ...

  5. 多线程异步导出excel

    先新建一个执行类 @Service public class MultiService { private static final Logger logger = LoggerFactory.get ...

  6. MyXls导出Excel的各种设置

    MyXls是一个操作Excel的开源类库,支持设置字体.列宽.行高(由BOSSMA实现).合并单元格.边框.背景颜色.数据类型.自动换行.对齐方式等,通过众多项目的使用表现,证明MyXls对于创建简单 ...

  7. 导入导出Excel工具类ExcelUtil

    前言 前段时间做的分布式集成平台项目中,许多模块都用到了导入导出Excel的功能,于是决定封装一个ExcelUtil类,专门用来处理Excel的导入和导出 本项目的持久化层用的是JPA(底层用hibe ...

  8. NPOI、MyXls、Aspose.Cells 导入导出Excel(转)

    Excel导入及导出问题产生: 从接触.net到现在一直在维护一个DataTable导s出到Excel的类,时不时还会维护一个导入类.以下是时不时就会出现的问题: 导出问题: 如果是asp.net,你 ...

  9. 分享我基于NPOI+ExcelReport实现的导入与导出EXCEL类库:ExcelUtility (续3篇-导出时动态生成多Sheet EXCEL)

    ExcelUtility 类库经过我(梦在旅途)近期不断的优化与新增功能,现已基本趋向稳定,功能上也基本可以满足绝大部份的EXCEL导出需求,该类库已在我们公司大型ERP系统全面使用,效果不错,今天应 ...

随机推荐

  1. css3学习之旅-css的基本语法(1)

    后面就将要介绍css的全面语法: 1.css介绍 2.css基本语法 3.css高级语法 4.css派生选择器 5.css的id选择器 6.css类选择器 7.css属性选择器 !!!!!css介绍 ...

  2. JAVA之旅(三)——数组,堆栈内存结构,静态初始化,遍历,最值,选择/冒泡排序,二维数组,面向对象思想

    JAVA之旅(三)--数组,堆栈内存结构,静态初始化,遍历,最值,选择/冒泡排序,二维数组,面向对象思想 我们继续JAVA之旅 一.数组 1.概念 数组就是同一种类型数据的集合,就是一个容器 数组的好 ...

  3. 【嵌入式开发】C语言 内存分配 地址 指针 数组 参数 实例解析

    . Android源码看的鸭梨大啊, 补一下C语言基础 ... . 作者 : 万境绝尘 转载请注明出处 : http://blog.csdn.net/shulianghan/article/detai ...

  4. 集团公司(嵌入ETL工具)财务报表系统解决方案

    集团公司(嵌入ETL工具)财务报表系统解决方案 一.项目背景: 某集团公司是一家拥有100多家子公司的大型集团公司,旗下子公司涉及各行各业,包括:金矿.铜矿.房产.化纤等.由于子公司在业务上的差异,子 ...

  5. Java-ServletConfig

    /** * * A servlet configuration object used by a servlet container * to pass information to a servle ...

  6. Android开发技巧——实现可复用的ActionSheet菜单

    在上一篇<Android开发技巧--使用Dialog实现仿QQ的ActionSheet菜单>中,讲了这种菜单的实现过程,接下来将把它改成一个可复用的控件库. 本文原创,转载请注明出处: h ...

  7. MTK如何烧录IMEI码(俗称串号)

    先介绍一下使用环境 主控:MT6582VX android版本:4.4.2 操作系统:windows XP SN烧录工具:SN_Write_tool_exe_v2.1420.00 首先介绍一下IMEI ...

  8. 一行代码实现FMDB的CURD操作

    上次实现FMDB的CURD基本操作后,用在项目里,每个实体类都要写SQL语句来实现创建表和CURD操作,总觉得太麻烦,然后就想着利用反射和kvc来实现一个数据库操作的基类继承一下,子类只需要继承,然后 ...

  9. How tomcat works 读书笔记十二 StandardContext 下

    对重载的支持 tomcat里容器对重载功能的支持是依靠Load的(在目前就是WebLoader).当在绑定载入器的容器时 public void setContainer(Container cont ...

  10. 如何使用ZOL一键安装器下载中关村在线的源安装包

    如何使用ZOL一键安装器下载中关村在线的源安装包 马根峰               (广东联合电子服务股份有限公司, 广州 510300) 摘要    中关村在线最近开始推出ZOL一键安装器,用户直 ...