.NET Core使用NPOI实现Excel的导入导出
以下是一个使用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工作簿,创建一个工作表,遍历一个字符串数组列表,并将每个字符串数组写入工作表的新行中。最后,将工作簿写入到一个文件中。
评论已关闭