.NET Core使用NPOI实现Excel的导入导出
    		       		warning:
    		            这篇文章距离上次修改已过423天,其中的内容可能已经有所变动。
    		        
        		                
                以下是一个使用NPOI在.NET Core中导入Excel文件的简单示例代码:
首先,确保已经通过NuGet安装了NPOI库。
using NPOI.SS.UserModel;
using NPOI.XSSF.UserModel;
using System.IO;
 
public List<string[]> ImportExcelFile(string filePath)
{
    IWorkbook workbook;
    using (FileStream file = new FileStream(filePath, FileMode.Open, FileAccess.Read))
    {
        workbook = new XSSFWorkbook(file); // 对于xlsx
        // 对于xls,使用HSSFWorkbook
    }
 
    var sheet = workbook.GetSheetAt(0); // 获取第一个工作表
    var rows = sheet.GetRowEnumerator();
 
    List<string[]> data = new List<string[]>();
 
    while (rows.MoveNext())
    {
        IRow row = rows.Current;
        int columns = row.LastCellNum;
        string[] cells = new string[columns];
 
        for (int i = 0; i < columns; i++)
        {
            ICell cell = row.GetCell(i);
            cells[i] = cell?.ToString();
        }
 
        data.Add(cells);
    }
 
    return data;
}这段代码展示了如何打开一个Excel文件,遍历第一个工作表中的所有行,并将每一行的单元格值读取到字符串数组中,然后将这些数组添加到一个列表中。
导出Excel的示例代码:
using NPOI.SS.UserModel;
using NPOI.XSSF.UserModel;
using System.IO;
 
public void ExportToExcel(List<string[]> data, string filePath)
{
    IWorkbook workbook = new XSSFWorkbook();
    ISheet sheet = workbook.CreateSheet("Sheet1");
 
    for (int i = 0; i < data.Count; i++)
    {
        IRow row = sheet.CreateRow(i);
        for (int j = 0; j < data[i].Length; j++)
        {
            row.CreateCell(j).SetCellValue(data[i][j]);
        }
    }
 
    using (FileStream stream = new FileStream(filePath, FileMode.Create, FileAccess.Write))
    {
        workbook.Write(stream);
    }
}这段代码展示了如何创建一个新的Excel工作簿,创建一个工作表,遍历一个字符串数组列表,并将每个字符串数组写入工作表的新行中。最后,将工作簿写入到一个文件中。
评论已关闭