npoi向已存在的Excel追加数据,保留原有数据

本文介绍如何使用NPOI库在已存在的Excel文件中追加数据,同时保留原有内容。通过具体代码示例,展示了如何创建或获取工作簿、设置列宽和行高、创建单元格并设置样式,最后将修改保存回原Excel文件。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

npoi向已存在的Excel追加数据,保留原有数据

直接上代码方法

/// <summary>
        /// 向已存在的excel追加数据
        /// </summary>
        /// <param name="excelPath">已存在的excel路径</param>
        /// <param name="rowIndex">追加行索引</param>
        /// <param name="cellData">追加列索引<列索引,单元格值></param>
        public void addExcelData(string excelPath, int rowIndex, IDictionary<int, string> cellData)
        {
            FileStream fs = new FileStream(excelPath, FileMode.Open, FileAccess.Read, FileShare.ReadWrite);//读取流
            POIFSFileSystem ps = new POIFSFileSystem(fs);//需using NPOI.POIFS.FileSystem;
            HSSFWorkbook workbook = new HSSFWorkbook(ps);
            ISheet sheet = workbook.GetSheetAt(0);//获取工作表

            //设置列宽
            SetColumnWidth(sheet, 0, 20);
            SetColumnWidth(sheet, 1, 10);
            IRow row = sheet.GetRow(rowIndex); //得到表头
            //设置行高
            row.Height =2 * 256;

            ICell cell = null;
            ICellStyle style = null;
            foreach (KeyValuePair<int, string> keyValue in cellData)
            {
                if (keyValue.Key == 1)
                {
                    cell = row.CreateCell(keyValue.Key);
                    cell.SetCellValue(keyValue.Value);
                   
                    style = workbook.CreateCellStyle();
                    //设置左对齐
                    style.Alignment = NPOI.SS.UserModel.HorizontalAlignment.LEFT;
                    //设置斜线
                    style.BorderDiagonal = BorderDiagonal.BACKWARD;
                    style.BorderDiagonalLineStyle = NPOI.SS.UserModel.BorderStyle.THIN;
                    //设置换行(若要单元格内换行必须加下面一句)
                    style.WrapText = true;
                    cell.CellStyle = style;
                }
                else
                {
                    cell = row.CreateCell(keyValue.Key);
                    cell.SetCellValue(keyValue.Value);

                    //设置居中
                    style = workbook.CreateCellStyle();
                    style.VerticalAlignment = VerticalAlignment.CENTER;
                    style.Alignment = NPOI.SS.UserModel.HorizontalAlignment.CENTER;
                    cell.CellStyle = style;
                }
            }

            FileStream fout = new FileStream(excelPath, FileMode.Open, FileAccess.Write, FileShare.ReadWrite);//写入流
            fout.Flush();
            workbook.Write(fout);//写入文件
            workbook = null;
            fout.Close();
        }
评论 9
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Mekeater

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值