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

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();
        }
  • 5
    点赞
  • 28
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 9
    评论
使用NPOI追加Excel数据可以使用以下步骤: 1. 打开Excel文件并定位到要追加数据的Sheet页: ```csharp using (var fileStream = new FileStream(filePath, FileMode.Open, FileAccess.ReadWrite)) { var workbook = new XSSFWorkbook(fileStream); var sheet = workbook.GetSheet(sheetName); // 定位到追加数据的行位置 var rowIndex = sheet.LastRowNum + 1; // ... } ``` 2. 创建要追加数据行并设置单元格的值: ```csharp var row = sheet.CreateRow(rowIndex); row.CreateCell(0).SetCellValue("value1"); row.CreateCell(1).SetCellValue("value2"); // ... ``` 3. 保存Excel文件: ```csharp fileStream.Position = 0; workbook.Write(fileStream); fileStream.Flush(); ``` 完整代码示例: ```csharp using NPOI.XSSF.UserModel; using NPOI.SS.UserModel; using System.IO; public void AppendExcelData(string filePath, string sheetName, object[] data) { using (var fileStream = new FileStream(filePath, FileMode.Open, FileAccess.ReadWrite)) { var workbook = new XSSFWorkbook(fileStream); var sheet = workbook.GetSheet(sheetName); // 定位到追加数据的行位置 var rowIndex = sheet.LastRowNum + 1; // 创建要追加数据行并设置单元格的值 var row = sheet.CreateRow(rowIndex); for (int i = 0; i < data.Length; i++) { row.CreateCell(i).SetCellValue(data[i].ToString()); } // 保存Excel文件 fileStream.Position = 0; workbook.Write(fileStream); fileStream.Flush(); } } ``` 注意:使用NPOI库操作Excel文件时,需要根据Excel文件的格式选择对应的Workbook类型,如XSSFWorkbook用于操作.xlsx文件,HSSFWorkbook用于操作.xls文件。同时,要确保Excel文件已经被释放,否则会出现文件被占用的异常。
评论 9
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

Mekeater

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

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

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

打赏作者

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

抵扣说明:

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

余额充值