ASP.NET Core中使用EPPlus導入出Excel文件的完整步驟
前言
這篇文章說明了如何使用EPPlus在ASP.NET Core中導入和導出.xls/.xlsx文件(Excel)。在考慮使用.NET處理excel時,我們總是尋找第三方庫或組件。使用Open Office Xml格式(xlsx)讀取和寫入Excel 2007/2010文件的最流行的.net庫之一是EPPlus。這個庫現(xiàn)在已經(jīng)支持.NET Core許久了。這適用于Windows,Linux和Mac。
因此,讓我們創(chuàng)建一個新的ASP.NET Core WEB API應用程序并安裝EPPlus.Core。要安裝EPPlus.Core,請在程序包管理器控制臺中運行以下命令:
PM->Install-Package EPPlus.Core
或者您可以通過UI界面來安裝它.

一切就緒,現(xiàn)在創(chuàng)建一個控制器,命名為: ImportExportController ,添加后,讓我們編寫導出方法。
為了方便演示,我在wwwroot文件夾中創(chuàng)建了一個excel文件,所以我們就需要去獲取我們的項目的絕對路徑。
public class ImportExportController : ControllerBase
{
private readonly IHostingEnvironment _hostingEnvironment;
public ImportExportController(IHostingEnvironment hostingEnvironment)
{
_hostingEnvironment = hostingEnvironment;
}
}
ExcelPackage 在 OfficeOpenXml 命名空間中可用的類將用于讀寫xlsx。定義名為“Export”的新Web api操作方法,該方法返回生成的xlsx文件的URL。所以這是將數(shù)據(jù)導出到xlsx的完整代碼。其中您需要 using OfficeOpenXml;
[HttpGet]
public string Export()
{
string sWebRootFolder = _hostingEnvironment.WebRootPath;
string sFileName = @"demo.xlsx";
string URL = string.Format("{0}://{1}/{2}", Request.Scheme, Request.Host, sFileName);
FileInfo file = new FileInfo(Path.Combine(sWebRootFolder, sFileName));
if (file.Exists)
{
file.Delete();
file = new FileInfo(Path.Combine(sWebRootFolder, sFileName));
}
using (ExcelPackage package = new ExcelPackage(file))
{
// add a new worksheet to the empty workbook
ExcelWorksheet worksheet = package.Workbook.Worksheets.Add("Employee");
//First add the headers
worksheet.Cells[1, 1].Value = "ID";
worksheet.Cells[1, 2].Value = "Name";
worksheet.Cells[1, 3].Value = "Gender";
worksheet.Cells[1, 4].Value = "Salary (in $)";
//Add values
worksheet.Cells["A2"].Value = 1000;
worksheet.Cells["B2"].Value = "Jon";
worksheet.Cells["C2"].Value = "M";
worksheet.Cells["D2"].Value = 5000;
worksheet.Cells["A3"].Value = 1001;
worksheet.Cells["B3"].Value = "Graham";
worksheet.Cells["C3"].Value = "M";
worksheet.Cells["D3"].Value = 10000;
worksheet.Cells["A4"].Value = 1002;
worksheet.Cells["B4"].Value = "Jenny";
worksheet.Cells["C4"].Value = "F";
worksheet.Cells["D4"].Value = 5000;
package.Save(); //Save the workbook.
}
return URL;
}
就這樣?,F(xiàn)在,當您運行此應用程序并調(diào)用export方法時。完成后,訪問wwwroot您的應用程序的文件夾。您應該在系統(tǒng)上看到“demo.xlsx”。當你打開它時,你應該看到以下內(nèi)容。

您還可以對標題進行加粗,這些并不是EPPlus.Core給我們提供的,你需要引用 using OfficeOpenXml; using OfficeOpenXml.Style;
using (var cells = worksheet.Cells[1, 1, 1, 4])
{
cells.Style.Font.Bold = true;
cells.Style.Fill.PatternType = ExcelFillStyle.Solid;
cells.Style.Fill.BackgroundColor.SetColor(Color.LightGray);
}
關于導入,其實真實的情況還是比較復雜的,我們這里就不進行驗證了,對于演示,我們只是讀取剛剛保存的文件。 ImportAPI 將讀取文件并以格式化的字符串返回文件內(nèi)容。以下是導入API的完整代碼,用于讀取xlsx,創(chuàng)建文件內(nèi)容的格式化字符串并返回相同的內(nèi)容。
[HttpGet]
[Route("Import")]
public string Import()
{
string sWebRootFolder = _hostingEnvironment.WebRootPath;
string sFileName = @"demo.xlsx";
FileInfo file = new FileInfo(Path.Combine(sWebRootFolder, sFileName));
try
{
using (ExcelPackage package = new ExcelPackage(file))
{
StringBuilder sb = new StringBuilder();
ExcelWorksheet worksheet = package.Workbook.Worksheets[1];
int rowCount = worksheet.Dimension.Rows;
int ColCount = worksheet.Dimension.Columns;
bool bHeaderRow = true;
for (int row = 1; row <= rowCount; row++)
{
for (int col = 1; col <= ColCount; col++)
{
if (bHeaderRow)
{
sb.Append(worksheet.Cells[row, col].Value.ToString() + "\t");
}
else
{
sb.Append(worksheet.Cells[row, col].Value.ToString() + "\t");
}
}
sb.Append(Environment.NewLine);
}
return sb.ToString();
}
}
catch (Exception ex)
{
return "Some error occured while importing." + ex.Message;
}
}
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
相關文章
Asp.net XMLHTTP封裝類(GET,Post發(fā)送和接收數(shù)據(jù))
XMLHTTP封裝類可以向遠程發(fā)送URL和參數(shù),接受返回信息(無亂碼)2008-11-11
ASP.NET Core Kestrel 中使用 HTTPS (SSL)
這篇文章主要為大家詳細介紹了ASP.NET Core Kestrel 中使用 HTTPS(SSL)的相關資料,感興趣的小伙伴們可以參考一下2016-09-09
MVC項目結(jié)構(gòu)搭建及單個類的實現(xiàn)學習筆記1
這篇文章主要介紹了MVC項目結(jié)構(gòu)搭建及單個類在各個層次中的實現(xiàn),具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-09-09
.Net?Api?中使用Elasticsearch存儲文檔的方法
Elasticsearch 是一個分布式、高擴展、高實時的搜索與數(shù)據(jù)分析引擎,在C# 的環(huán)境中,有一個Es的官方拓展包Nest,可以讓我們方便快捷的使用上Es數(shù)據(jù)庫,本文重點給大家介紹.Net?Api?中使用Elasticsearch存儲文檔的方法,感興趣的朋友一起看看吧2022-01-01
asp.net使用DataSet的ReadXml讀取XML文件及Stream流的方法
這篇文章主要介紹了asp.net使用DataSet的ReadXml讀取XML文件及Stream流的方法,實例分析了asp.net以字符流的形式讀取與寫入xml文件的相關技巧,需要的朋友可以參考下2016-06-06

