EPPlus應用筆記

C#窗體程序中經常會使用到對數據的輸入輸出,而Excel文件是比較通用的文本格式,針對功能需求:

  • 快速方便讀寫Excel文件
  • 對於未安裝Office的機器也能具備生成和讀寫Excel的能力

通常有NPOI、ClosedXML、EPPlus等類庫可供使用,本文對EPPlus的簡單使用做一總結。

EPPlus的GitHub網址:https://github.com/EPPlusSoftware/EPPlus
EPPlus版本:5.0.4

讀取Excel文件至二維數組:

FileInfo file = new FileInfo(@"數據.xlsx");

ExcelPackage excelPackage = new ExcelPackage(file);
//許可證,必須添加許可證,否則會報錯
ExcelPackage.LicenseContext = OfficeOpenXml.LicenseContext.NonCommercial;
//選擇讀取的數據表
ExcelWorksheet excelWorksheet = excelPackage.Workbook.Worksheets["Sheet1"];
//獲取表格數據的最大行數        
int rowNum = excelWorksheet.Dimension.End.Row;
//獲取表格數據的最大列數
int columnNum = excelWorksheet.Dimension.End.Column;
//定義存儲數據的二維數組
string[,] dataTable = new string[rowNum, columnNum];

//按行讀取,存入二維數組dataTable
for (int i = excelWorksheet.Dimension.Start.Row; i <= excelWorksheet.Dimension.End.Row; i++)
{
	for (int j = excelWorksheet.Dimension.Start.Column; j <= excelWorksheet.Dimension.End.Column; j++)
    {
    	dataTable[i - 1, j - 1] = excelWorksheet.Cells[i, j].Value.ToString();
    }
}

//將數組遍歷輸出
for (int i = 0; i < dataTable.GetLength(0); i++)
{
	for (int j = 0; j < dataTable.GetLength(1); j++)
    {
    	Console.Write(dataTable[i, j] + "\t");
    }
    Console.Write("\n");
}
Console.ReadKey();

將數組寫入Excel表

//待寫入的數組,及Excel表存儲位置
string[] str = { "1", "5", "10", "15", "20" };
string outputExcelPath = System.Environment.CurrentDirectory + "\\數據.xlsx";
FileInfo file = new FileInfo(outputExcelPath);
//許可證
ExcelPackage.LicenseContext = OfficeOpenXml.LicenseContext.NonCommercial;

//如果文件存在,則讀取並寫入新的列,若不存在則創建
if (file.Exists)
{
	ExcelPackage excelPackage = new ExcelPackage(file);
    //選擇讀取的數據表
    ExcelWorksheet excelWorksheet = excelPackage.Workbook.Worksheets["Sheet1"];
    //獲取表格中已有數據的列數
    int columnNum = excelWorksheet.Dimension.End.Column;
    //寫入數據
    excelWorksheet.Cells[1, columnNum + 1].Value = "新數據";
    for (int i = 0; i < str.Length; i++)
    {
    	excelWorksheet.Cells[i + 2, columnNum + 1].Value = str[i];
    }
    excelPackage.Save();
}
else
{
	file = new FileInfo(outputExcelPath);
    ExcelPackage excelPackage = new ExcelPackage(file);
    //創建新的數據表
    ExcelWorksheet excelWorksheet = excelPackage.Workbook.Worksheets.Add("Sheet1");
    //寫入數據
    excelWorksheet.Cells[1, 1].Value = "數據";
    for (int i = 0; i < str.Length; i++)
    {
    	excelWorksheet.Cells[i + 2, 1].Value = str[i];
    }
    excelPackage.Save();
}

運行結果:
在這裏插入圖片描述
End

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章