C#使用Npoi导出Excel并合并行列

在工作开发中,客户经常要求数据库中数据导出到Excel表格。以前方法是引用office相关组件,如果客户没有安装office,功能就会遇到问题。

现在用Npoi导出Excel,导出表格是合并行列,如图:

导出的要求:合计列要进行合并,序号一致的要合并。最后一行要合并列。
因为相同序号数量不是固定的,要动态算合并的行数。

合并行列接口:XXX.AddMergedRegion(new CellRangeAddress(开始行, 最后一行, 开始列, 最后一列));

隐藏指定:sheet.SetColumnHidden(cellIndex, true);

引用组件:

NPOI.dll;
NPOI.OOXML.dll;
NPOI.OpenXml4Net.dll;
NPOI.OpenXmlFormats.dll;
ICSharpCode.SharpZipLib.dll;

代码如下:

/// <summary>
/// 
/// </summary>
/// <param name="dtSource">数据源</param>
/// <param name="strFileName">保存路径</param>
/// <param name="dvXH">序号</param>
public void Export(DataTable dtSource,string strFileName,DataView dvXH=null)
        {
            //创建工作簿 office2007以上
            XSSFWorkbook workbook = new XSSFWorkbook();
            //为工作簿创建工作表并命名
            ISheet sheet = workbook.CreateSheet("商品表");

            ICellStyle dateStyle = workbook.CreateCellStyle();

            IDataFormat format = workbook.CreateDataFormat();
            dateStyle.DataFormat = format.GetFormat("yyyy-mm-dd");

            #region 表头及样式
            int cellIndex = 0;
            IRow headerRow = sheet.CreateRow(0);
            for (int i = 0; i < dtSource.Columns.Count; i++)
            {
                #region MyRegion
                string ColumnsName = dtSource.Columns[i].ToString();
                if (dtSource.Columns[i].ColumnName.EndsWith("XH"))
                {
                    ColumnsName = "序号";
                    sheet.SetColumnWidth(cellIndex, 3000);
                   //sheet.SetColumnHidden(cellIndex, true);隐藏指定列
                }
                else if (dtSource.Columns[i].ColumnName.EndsWith("GoogName"))
                {
                    ColumnsName = "商品名称";
                    sheet.SetColumnWidth(cellIndex,10000);//设置列宽
                }
                else if (dtSource.Columns[i].ColumnName.EndsWith("Num"))
                {
                    ColumnsName = "数量";
                    sheet.SetColumnWidth(cellIndex, 5000);
                }

                else if (dtSource.Columns[i].ColumnName.EndsWith("Summation"))
                {
                    ColumnsName = "合计(元)";
                    sheet.SetColumnWidth(cellIndex, 5000);
                }
                #endregion

                //设置行高
                headerRow.HeightInPoints = 35; 
                headerRow.CreateCell(cellIndex).SetCellValue(ColumnsName);

                ICellStyle headStyle = workbook.CreateCellStyle();
                headStyle.WrapText = true;
                IFont font = workbook.CreateFont();
                //字体大小
                font.FontHeightInPoints = 12;
                font.Boldweight = 360;
                headStyle.SetFont(font);
                headerRow.GetCell(cellIndex).CellStyle = headStyle;
                cellIndex++;
            }
            #endregion

            int rowIndex = 1;//行数一定要从1行开始
            int count = 1;
            int startRow = 1;
            DataView dvSource = dtSource.DefaultView;
            if (dvXH!=null)
            {
                foreach (DataRowView drv in dvXH)
                {//1-10.11-12,13-14,15-16
                    int rowcout = 0;
                    dvSource.RowFilter = "XH='" + drv["XH"] + "'";
                    foreach (DataRowView row in dvSource)
                    {
                        #region 填充内容
                        IRow dataRow = sheet.CreateRow(rowIndex);

                        //序号
                        ICell newCel0 = dataRow.CreateCell(0);
                        ICellStyle style0 = workbook.CreateCellStyle();
                        style0.DataFormat = format.GetFormat("text");
                        newCel0.SetCellValue(row["XH"].ToString());

                        //标的名称
                        ICell newCel2 = dataRow.CreateCell(1);
                        ICellStyle style2 = workbook.CreateCellStyle();
                        style2.DataFormat = format.GetFormat("text");
                        newCel2.SetCellValue(row["GoogName"].ToString());

                        //标的数量
                        ICell newCel4 = dataRow.CreateCell(2);
                        ICellStyle style4 = workbook.CreateCellStyle();
                        style4.DataFormat = format.GetFormat("text");
                        newCel4.SetCellValue(row["Num"].ToString());

                        //合计(元)
                        ICell newCel8 = dataRow.CreateCell(3);
                        ICellStyle style8 = workbook.CreateCellStyle();
                        style8.DataFormat = format.GetFormat("text");
                        newCel8.SetCellValue(row["Summation"].ToString());
                        #endregion

                        rowIndex++;
                        rowcout++;
                    }

                    if (count == 1)
                    {
                        //合并行数
                        sheet.AddMergedRegion(new CellRangeAddress(startRow, rowcout, 3, 3));
                        startRow = startRow + rowcout;
                    }
                    else
                    {
                        sheet.AddMergedRegion(new CellRangeAddress(startRow, startRow + rowcout - 1, 3, 3));
                        startRow = startRow + rowcout;
                    }
                    count++;
                }
            }
            else
            {
                #region MyRegion
                foreach (DataRowView row in dvSource)
                {
                    #region 填充内容
                    IRow dataRow = sheet.CreateRow(rowIndex);

                    //序号
                    ICell newCel0 = dataRow.CreateCell(0);
                    ICellStyle style0 = workbook.CreateCellStyle();
                    style0.DataFormat = format.GetFormat("text");
                    newCel0.SetCellValue(row["XH"].ToString());
              
                    //商品名称
                    ICell newCel1 = dataRow.CreateCell(1);
                    ICellStyle style1 = workbook.CreateCellStyle();
                    style1.DataFormat = format.GetFormat("text");
                    newCel1.SetCellValue(row["GoogName"].ToString());

                    //数量
                    ICell newCel2 = dataRow.CreateCell(2);
                    ICellStyle style2 = workbook.CreateCellStyle();
                    style2.DataFormat = format.GetFormat("text");
                    newCel2.SetCellValue(row["Num"].ToString());
                   
                    //合计(元)
                    ICell newCel3 = dataRow.CreateCell(3);
                    ICellStyle style3 = workbook.CreateCellStyle();
                    style3.DataFormat = format.GetFormat("text");
                    newCel3.SetCellValue(row["Summation"].ToString());
                    #endregion
                    rowIndex++;
                }
                #endregion
            }
            #region 拼接最后一行
            IFont fontLast = workbook.CreateFont();
            fontLast.FontHeightInPoints = 30;
            fontLast.Boldweight = 480;
            IRow dataRowLast = sheet.CreateRow(rowIndex);
            dataRowLast.HeightInPoints = 40;
            ICell newCelLast = dataRowLast.CreateCell(0);
            ICellStyle styleLast = workbook.CreateCellStyle();
            styleLast.DataFormat = format.GetFormat("text");
            styleLast.SetFont(fontLast);
            newCelLast.SetCellValue("制作人:张三");
            sheet.AddMergedRegion(new CellRangeAddress(rowIndex, rowIndex, 0, 3));
            #endregion

            MemoryStream stream = new MemoryStream();
            workbook.Write(stream);
            var buf = stream.ToArray();
            using (FileStream fs = new FileStream(strFileName, FileMode.Create, FileAccess.Write))
            {
                fs.Write(buf, 0, buf.Length);
                fs.Flush();
            }
} 

实际运用中,涉及到数据,方法中有很多校验等操作,方法直观可读性不是太好,下面附上简单导出的方法:

实际上导出Excel,总结有几点:

1、引用相关组件
2、创建一个工作簿,创建工作表并命名;
3、设置表头及样式;
4、填充数据;
5、保存数据到指定位置;

/// <summary>
/// 简单导出数据
/// </summary>
/// <param name="dtSource">数据源</param>
/// <param name="strFileName">保存路径</param>
/// <param name="dvXH">序号</param>
        public void Export1(DataTable dtSource, string strFileName)
        {
            //创建工作簿
            XSSFWorkbook workbook = new XSSFWorkbook();
            //为工作簿创建工作表并命名
            ISheet sheet = workbook.CreateSheet("商品表");
            IDataFormat format = workbook.CreateDataFormat();

            #region 表头及样式
            int cellIndex = 0;
            IRow headerRow = sheet.CreateRow(0);
            for (int i = 0; i < dtSource.Columns.Count; i++)
            {
                //设置行高
                headerRow.HeightInPoints = 35;
                headerRow.CreateCell(cellIndex).SetCellValue(dtSource.Columns[i].ToString());
                ICellStyle headStyle = workbook.CreateCellStyle();
                headStyle.WrapText = true;
                IFont font = workbook.CreateFont();
                //字体大小
                font.FontHeightInPoints = 12;
                font.Boldweight = 360;
                headStyle.SetFont(font);
                headerRow.GetCell(cellIndex).CellStyle = headStyle;
                cellIndex++;
            }
            #endregion

            #region 数据填充
            int rowIndex = 1;//行数一定要从1行开始,因为上面已经创建了表头为0行;
            DataView dvSource = dtSource.DefaultView;

            foreach (DataRow row in dtSource.Rows)
            {
                int ColumnIndex = 0;
                IRow dataRow = sheet.CreateRow(rowIndex);
                foreach (DataColumn column in dtSource.Columns)
                {
                    //序号
                    ICell newCel0 = dataRow.CreateCell(ColumnIndex);
                    ICellStyle style0 = workbook.CreateCellStyle();
                    style0.DataFormat = format.GetFormat("text");//数据类型
                    newCel0.SetCellValue(row[column.ColumnName].ToString());
                    ColumnIndex++;
                }
                rowIndex++;
            }
            #endregion

            #region 保存到指定位置
            MemoryStream stream = new MemoryStream();
            workbook.Write(stream);
            var buf = stream.ToArray();
            using (FileStream fs = new FileStream(strFileName, FileMode.Create, FileAccess.Write))
            {
                fs.Write(buf, 0, buf.Length);
                fs.Flush();
            }
            #endregion

}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • c# 应用NPOI获取Excel中的图片,保存至本地的算法

    要求:读取excel中的图片,保存到指定路径 思路:  利用NPOI中 GetAllPictures()方法获取图片信息 步骤: 1.新建一个Windows窗体应用程序 2.桌面新建一个excel,贴入两张图片 如下图: 3.在Form中拖入一个button 4.点击button,在点击事件方法中写入,要读取图片的方法:ExcelToImage 点击事件方法如下: private string exclePath = @"C:\users\lenovo\Desktop\testPic.xls&q

  • C#通过NPOI操作Excel的实例代码

    C#操作Excel的方法有很多种,常见的有微软官方的OLE Automation,Apache的POI等.这里介绍的是POI翻译成C#的NPOI. POI是Apache的通过Java操作Office的一个API,可以对Excel,Word,PPT等进行操作,十分的强大.然后就被翻译成C#版本的NPOI了,和log4j与log4net很相似. 好像在NPOI的.net4.0版本之前是不支持office2007及以上的XML格式的,但是最新的版本已经支持了.只需要下载并引用下面五个程序集就能使用了.

  • C#基于NPOI生成具有精确列宽行高的Excel文件的方法

    本文实例讲述了C#基于NPOI生成具有精确列宽行高的Excel文件的方法,是非常具有实用价值的技巧分享给大家供大家参考.具体方法如下:. 一.前言 NPOI是操作Excel的神器,导出导入快如闪电, 但是SetColumnWidth函数个人感觉不会用,怎么弄都无法控制好,因为他是以字符数量去设置宽度,实际上Excel列宽还有个像素的概念,更难搞懂了. //附带SetColumnWidth的用法和注释 IWorkbook hssfworkbook = new HSSFWorkbook(); ISh

  • c#中合并excel表格的方法示例

    有多个结构一样的Excel,带复杂表头需要合并为一个,且去掉多余的表头数据,可以用COM组件来读取每个Excel表格的Range来合并到一个新的表格中.样例如图 有很多相同格式的表格,合并代码如下: using System; using System.Collections.Generic; using System.Text; using System.Reflection; using Excel = Microsoft.Office.Interop.Excel; namespace Co

  • 基于NPOI用C#开发的Excel以及表格设置

    本文为大家分享了基于NPOI用C#开发的Excel以及表格设置,供大家参考,具体内容如下 最近在项目中需要导出Excel.在这里做个记录.在网上查阅了一些资料.将自己最终的代码分享在这里,以供自己日后查阅,如果能给陌生的你带来方便,那便更好. 开发的过程中也遇到了一个问题,设置字体会导致打开Excel时报错(错误:此文件中的某些文本格式可能已经更改,因为它已经超出最多允许的字体数),并且设置失败.这个问题产生的原因是因为频繁的创建字体,这个在我参考的代码中是有问题,我做了些改善.如果你有更优的方

  • c# 根据NPOI 读取一个excel 文件的多个Sheet

    大家都知道NPOI组件可以在你本地没有安装office的情况下来 读取,创建excel文件.但是大家一般都是只默认读取一个excel文件的第一个sheet.那么如果要读取一个excel 的所有sheet 要怎么做呢? 下面就来告诉大家如何操作NPOI 读取excel 的所有sheet. 首先我们先讲解操作excel 单独创建的一个类,我命名为 EXECLHELP using NPOI.HSSF.UserModel; using NPOI.SS.UserModel; using NPOI.XSSF

  • C# 基于NPOI操作Excel

    目录 1 单元格下拉框 2 添加批注 3 读取数据 结语 常见问题解决 NPOI 导出添加批注功能 POI导出Excel时下拉列表值超过255的问题 日期格式导入混乱 注意 1 单元格下拉框 在开发中我们会遇到为单元格设置下拉框.一般可以编写如下: var cellRanges = new CellRangeAddressList(firstRow, lastRow, firstCol, latsCol); DVConstraint constraint = DVConstraint.Creat

  • C#利用NPOI操作Excel(单元格设置)

    本文实例为大家分享了C#利用NPOI操作Excel的单元格设置,供大家参考,具体内容如下 一.合并单元格 NOPI支持对单元格进行合并,还有单元格格式设置! 注意: 在进行单元格合并时必须先创建单元格 1.合并单元格语句: sheet.AddMergedRegion(new CellRangeAddress(0, 0, 0, 3)); //起始行,终止行,起始列,终止列 2.设置单元格格式: ICellStyle cellStyle = wk.CreateCellStyle();  //首先建单

  • C#使用NPOI导入Excel的方法详解

    本文实例讲述了C#使用NPOI导入Excel的方法.分享给大家供大家参考,具体如下: NPOI是由国人开发的一个进行excel操作的第三方库.百度百科介绍如下:NPOI 本文主要介绍如何使用NPOI将Excel数据读取. 首先引入程序集: using System.IO; using System.Reflection; using NPOI.HSSF.UserModel; using NPOI.SS.UserModel; using System.Web; 然后定位到文件位置: string

  • C#使用Npoi导出Excel并合并行列

    在工作开发中,客户经常要求数据库中数据导出到Excel表格.以前方法是引用office相关组件,如果客户没有安装office,功能就会遇到问题. 现在用Npoi导出Excel,导出表格是合并行列,如图: 导出的要求:合计列要进行合并,序号一致的要合并.最后一行要合并列.因为相同序号数量不是固定的,要动态算合并的行数. 合并行列接口:XXX.AddMergedRegion(new CellRangeAddress(开始行, 最后一行, 开始列, 最后一列)); 隐藏指定:sheet.SetColu

  • Java导出excel时合并同一列中相同内容的行思路详解

    一.有时候导出Excel时需要按类别导出,一大类下好几个小类,小类下又有好几个小小类,就像下图: 要实现这个也不难, 思路如下:按照大类来循环,如上就是按照张江校区.徐汇校区.临港校区三个大类循环,然后再处理小类,因为本例小小类不涉及合并,所以只涉及处理小类,如果需要处理小小类,还需要在处理一下,具体实现原理同小类: 每次循环时记录下此次循环的房屋类型和上次循环的房屋类型,两者相同时,要合并的结束行++,否者,说明这个房屋类型已经循环完毕(前提是各类型都按顺序order by 了,保证相同类型相

  • asp.net 利用NPOI导出Excel通用类的方法

    解决中文文件名保存Excel乱码问题,主要是判断火狐或者IE浏览器,然后做对应的判断处理,核心代码如下: System.Web.HttpContext.Current.Response.ContentType = "application/vnd.ms-excel"; //设置下载的Excel文件名\ if (System.Web.HttpContext.Current.Request.ServerVariables["http_user_agent"].ToStr

  • Vue+axios+WebApi+NPOI导出Excel文件实例方法

    一.前言 项目中前端采用的Element UI 框架, 远程数据请求,使用的是axios,后端接口框架采用的asp.net webapi,数据导出成Excel采用NPOI组件.其业务场景,主要是列表页(如会员信息,订单信息等)表格数据导出,如表格数据进行了条件筛选,则需要将条件传至后端api,筛选数据后,导出成Excel. 思考过前端导出的3种方案: 1.使用location.href 打开接口地址.缺点: 不能传token至后端api, 无法保证接口的安全性校验,并且接口只能是get方式请求.

  • C#使用NPOI导出Excel类封装

    ** NPOI是指构建在POI 3.x版本之上的一个程序,NPOI可以在没有安装Office的情况下对Word或Excel文档进行读写操作. NPOI是一个开源的C#读写Excel.WORD等微软OLE2组件文档的项目.** 以下代码主要分3部分:通过实体类的自定义特性导出Excel文件 1.封装类:ExcelHelper2.实体类:StudentModel3.调用:Form1 ExcelHelper  /// <summary> /// Excel操作类 /// </summary&g

  • 用NPOI创建Excel、合并单元格、设置单元格样式、边框的方法

    今天在做项目中,遇到使用代码生成具有一定样式的Excel,找了很多资料,最后终于解决了,Excel中格式的设置,以及单元格的合并等等.下面就介绍下,使用NPOI类库操作Excel的方法. 1.首先我们先在内存中生成一个Excel文件,代码如下:   HSSFWorkbook book = new HSSFWorkbook();        ISheet sheet = book.CreateSheet("Sheet1"); 2.然后在新创建的sheet里面,创建我们的行和列,代码如下

  • asp.net使用npoi读取excel模板并导出下载详解

    为什么要使用NPOI导出Excel? 一.解决传统操作Excel遇到的问题: 如果是.NET,需要在服务器端装Office,且及时更新它,以防漏洞,还需要设定权限允许.NET访问COM+,如果在导出过程中出问题可能导致服务器宕机.Excel会把只包含数字的列进行类型转换,本来是文本型的,Excel会将其转成数值型的,比如编号000123会变成123.导出时,如果字段内容以"-"或"="开头,Excel会把它当成公式进行,会报错.Excel会根据Excel文件前8行分

  • Asp.Net使用Npoi导入导出Excel的方法

    asp.net针对Excel文件的导入与导出是非常常见的功能之一.本文实例讲述了Asp.Net使用Npoi导入导出Excel的方法.分享给大家供大家参考之用.具体方法如下: 在使用Npoi导出Excel的时候,服务器可以不装任何office组件,一般在导出时用到Npoi导出Excel文件,所导Excel也符合规范,打开时也不会有任何文件损坏之类的提示.但是在做导入时还是使用OleDb的方式,这种方式的导入在服务器端似乎还是需要装office组件的. 一.Npoi导出/下载Excel 具体功能代码

  • C#使用NPOI对Excel数据进行导入导出

    目录 一.概述 1.操作Excel的类库: 2.引用DLL 程序集构成 二.通过NPOI,将Excel文件导到数据表DataTable 四.常见用法: 1.查找 2.插入图片 五.填充Excel模板 六.DataTable导出到Excel文件 1.直接导出到Excel: 2.将DataTable导出到Excel:先导出到MemoryStream 3.应用 1.Web导出 2.Winform导出 一.概述 NPOI 是 POI 项目的 .NET 版本.POI是一个开源的Java读写Excel.WO

随机推荐