我的编程空间,编程开发者的网络收藏夹
学习永远不晚

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

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

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

这篇文章主要讲解了“C#中怎么使用Npoi导出Excel合并行列”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C#中怎么使用Npoi导出Excel合并行列”吧!

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

C#中怎么使用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,总结有几点:

引用相关组件
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}

感谢各位的阅读,以上就是“C#中怎么使用Npoi导出Excel合并行列”的内容了,经过本文的学习后,相信大家对C#中怎么使用Npoi导出Excel合并行列这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

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

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

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

这篇文章主要讲解了“C#中怎么使用Npoi导出Excel合并行列”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C#中怎么使用Npoi导出Excel合并行列”吧!现在用Npoi导出Excel,
2023-06-29

怎么用C#实现NPOI的Excel导出

这篇文章主要讲解了“怎么用C#实现NPOI的Excel导出”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么用C#实现NPOI的Excel导出”吧!技术点:1.自定义attribute属性2
2023-06-26

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

本篇内容介绍了“C#如何使用NPOI对Excel数据进行导入导出”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、概述NPOI 是 POI
2023-07-02

C#中如何使用NPOI实现Excel导入导出功能

本文小编为大家详细介绍“C#中如何使用NPOI实现Excel导入导出功能”,内容详细,步骤清晰,细节处理妥当,希望这篇“C#中如何使用NPOI实现Excel导入导出功能”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧
2023-06-29

C#中如何使用NPOI将List数据导出到Excel文档

今天小编给大家分享一下C#中如何使用NPOI将List数据导出到Excel文档的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。
2023-06-29

C#中怎么使用NPOI读取excel转为DataSet

这篇文章主要介绍了C#中怎么使用NPOI读取excel转为DataSet的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇C#中怎么使用NPOI读取excel转为DataSet文章都会有所收获,下面我们一起来看看吧
2023-06-29

C#中怎么使用NPOI库读写Excel文件

今天小编给大家分享一下C#中怎么使用NPOI库读写Excel文件的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。第一步添加程引
2023-06-29

怎么在c#中利用NPOI 在指定单元格中导入导出图片

怎么在c#中利用NPOI 在指定单元格中导入导出图片?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。导入Excel 时解析图片xls 和 xlsx 的 API 稍有不同,详细
2023-06-06

使用canvas怎么拼合图片并导出

今天就跟大家聊聊有关使用canvas怎么拼合图片并导出,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。canvas绘图的基本方法,如下:const myCanvas = documen
2023-06-09

C#中怎么使用datagridview获取某行某列的值

在C#中,可以使用DataGridView的Rows和Columns属性来获取指定行和列的值。首先,使用Rows属性获取指定行的DataGridViewRow对象,然后使用Cells属性获取该行中指定列的DataGridViewCell对象
2023-09-27

Pandas中怎么使用MultiIndex选择并提取任何行和列

这篇文章主要介绍“Pandas中怎么使用MultiIndex选择并提取任何行和列”,在日常操作中,相信很多人在Pandas中怎么使用MultiIndex选择并提取任何行和列问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对
2023-07-05

怎么在c#中使用Parallelx实现并行和多线程编程

本篇文章给大家分享的是有关怎么在c#中使用Parallelx实现并行和多线程编程,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。一、 Parallel的使用1、Parallel.
2023-06-06

怎么使用C语言将数字和字符等数据写入并输出到文本文件中

这篇文章主要介绍“怎么使用C语言将数字和字符等数据写入并输出到文本文件中”,在日常操作中,相信很多人在怎么使用C语言将数字和字符等数据写入并输出到文本文件中问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么使
2023-07-02

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录