首頁 >後端開發 >C++ >如何使用 EPPlus 將 ASP.NET MVC 中的資料高效能匯出到 Excel?

如何使用 EPPlus 將 ASP.NET MVC 中的資料高效能匯出到 Excel?

Linda Hamilton
Linda Hamilton原創
2025-01-06 02:18:40874瀏覽

How to Efficiently Export Data to Excel from ASP.NET MVC using EPPlus?

如何在ASP.NET MVC 中有效地將資料匯出到Excel

提供的指南嘗試使用效率較低的HTML 將資料匯出到Excel基於的方法。要建立正確的 Excel 文件,建議使用 EPPlus 等庫。

EPPlus 函式庫

EPPlus 提供 LoadFromDataTable 和 LoadFromCollection 方法來以資料填入 Excel 範圍。以下是如何在程式碼中實現它:

程式碼:

using (ExcelPackage package = new ExcelPackage())
{
    var ws = package.Workbook.Worksheets.Add("My Sheet");
    //true generates headers
    ws.Cells["A1"].LoadFromDataTable(dataTable, true);
}

預設情況下,列或屬性名稱將用作標題。您也可以使用 EPPlus 庫應用程式格式設定、表格樣式等。

儲存到文件

要儲存 Excel 文件,請建立一個名為的自訂 FileResult EpplusResult:

代碼:

public class EpplusResult:FileResult
{
    public EpplusResult(ExcelPackage package) : base("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet")
    {
        Package = package;
    }

    public ExcelPackage Package { get; private set; }
}

這允許您編寫以下操作:

代碼:

public FileResult ExportData()
{
    ExcelPackage package = new ExcelPackage();
    var ws = package.Workbook.Worksheets.Add("My Sheet");       
    // Load data to the worksheet
    ws.Cells[1, 1].LoadFromDataTable(table, true, TableStyles.Light1);

    return new EpplusResult(package) { FileDownloadName = "SomeFile.xlsx" };
}

代碼:

代碼:

代碼:

public ActionResult ExportData()
{
    var pagedList = db.Customers.ToPagedList(pageNumber, pageSize);

    ExcelPackage package = new ExcelPackage();
    var ws = package.Workbook.Worksheets.Add("My Sheet");       
    ws.Cells[1, 1].LoadFromCollection(pagedList, true, TableStyles.Light1);

    return new EpplusResult(package) { FileDownloadName = "Customers.xlsx" };
}
代碼:獎勵:匯出分頁資料要使用PagedList匯出分頁數據,可以修改action:程式碼:

以上是如何使用 EPPlus 將 ASP.NET MVC 中的資料高效能匯出到 Excel?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn