>백엔드 개발 >C++ >EPPlus를 사용하여 ASP.NET MVC에서 Excel로 데이터를 효율적으로 내보내는 방법은 무엇입니까?

EPPlus를 사용하여 ASP.NET MVC에서 Excel로 데이터를 효율적으로 내보내는 방법은 무엇입니까?

Linda Hamilton
Linda Hamilton원래의
2025-01-06 02:18:40854검색

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

ASP.NET MVC에서 효과적으로 Excel로 데이터를 내보내는 방법

제공된 가이드에서는 덜 효율적인 HTML을 사용하여 데이터를 Excel로 내보내려고 시도합니다. 기반 접근 방식. 적절한 Excel 파일을 생성하려면 EPPlus와 같은 라이브러리를 활용하는 것이 좋습니다.

EPPlus 라이브러리

EPPlus는 Excel 범위를 데이터로 채우는 LoadFromDataTable 및 LoadFromCollection 메서드를 제공합니다. . 코드에서 이를 구현하는 방법은 다음과 같습니다.

코드:

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" };
}

보너스: 페이지 내보내기 데이터

PagedList를 사용하여 페이징된 데이터를 내보내려면 작업을 수정할 수 있습니다.

코드:

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" };
}

위 내용은 EPPlus를 사용하여 ASP.NET MVC에서 Excel로 데이터를 효율적으로 내보내는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.