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

 更新时间:2022年02月21日 14:17:27   作者:曹悠然  
这篇文章主要为大家详细介绍了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

}

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

相关文章

  • UGUI实现随意调整Text中的字体间距

    UGUI实现随意调整Text中的字体间距

    这篇文章主要为大家详细介绍了UGUI实现随意调整字体间距的方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-03-03
  • C#设置或验证PDF文本域格式的方法详解

    C#设置或验证PDF文本域格式的方法详解

    PDF中的文本域可以通过设置不同格式,用于显示数字、货币、日期、时间、邮政编码、电话号码和社保号等等。本文将介绍如何通过C#设置或验证PDF文本域格式,需要的可以参考一下
    2022-01-01
  • C#使用SQLDMO操作数据库的方法

    C#使用SQLDMO操作数据库的方法

    这篇文章主要介绍了C#使用SQLDMO操作数据库的方法,实例分析了基于SQLDMO.dll动态链接库操作数据库的相关技巧,需要的朋友可以参考下
    2015-06-06
  • C# 使用AE获取feature的属性及字段操作

    C# 使用AE获取feature的属性及字段操作

    这篇文章主要介绍了C# 使用AE获取feature的属性及字段操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-01-01
  • C#判断指定分区是否是ntfs格式的方法

    C#判断指定分区是否是ntfs格式的方法

    这篇文章主要介绍了C#判断指定分区是否是ntfs格式的方法,涉及C#中DriveFormat属性的使用技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-04-04
  • C#(int)中Convert、Parse、TryParse的区别

    C#(int)中Convert、Parse、TryParse的区别

    Convert.ToInt32、int.Parse(Int32.Parse)、int.TryParse、(int) 四者都可以解释为将类型转换为 int,那它们的区别是什么呢?
    2013-04-04
  • C#中异步和多线程的区别介绍

    C#中异步和多线程的区别介绍

    这篇文章介绍了C#中异步和多线程的区别,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-05-05
  • C#中GraphicsPath的Widen方法用法实例

    C#中GraphicsPath的Widen方法用法实例

    这篇文章主要介绍了C#中GraphicsPath的Widen方法用法,实例分析了Widen方法的使用技巧,需要的朋友可以参考下
    2015-06-06
  • c#测试本机sql运算速度的代码示例分享

    c#测试本机sql运算速度的代码示例分享

    本文代码目的很简单,就是使用c#测试一下本机sql运算的速度,使用循环往数据里大量插入数据,计算所用时间,大家参考使用吧
    2014-01-01
  • C#事件处理和委托event delegate实例简述

    C#事件处理和委托event delegate实例简述

    这篇文章主要介绍了C#事件处理和委托event delegate的简单实例,较为详细的讲述了C#事件处理和委托的声明与实现过程,代码简单易懂,需要的朋友可以参考下
    2014-09-09

最新评论