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

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

Barbara Streisand
Barbara Streisand원래의
2025-01-05 15:28:40239검색

How to Efficiently Export Data to Excel Using EPPlus?

데이터를 Excel로 내보내는 방법

제공된 가이드는 테이블이 포함된 HTML 파일을 생성하는 해결 방법을 보여 주지만 다음과 같은 경우 이 접근 방식을 신뢰할 수 없습니다. Excel은 이러한 파일을 해석하고 가져옵니다. 더 효과적인 방법은 EPPlus와 같은 라이브러리를 사용하여 전용 Excel 파일을 만드는 것입니다.

EPPlus 사용

EPPlus는 Excel 범위를 채우는 LoadFromDataTable 및 LoadFromCollection 메서드를 제공합니다. 각각 데이터 테이블 또는 일반 컬렉션의 데이터를 사용합니다. 열 또는 속성 이름은 로드 중에 헤더 역할을 합니다.

예제 코드:

public ActionResult ExportData()
{
    DataTable dataTable = GetData(); // Method to retrieve data

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

        var stream = new MemoryStream();
        package.SaveAs(stream);

        string fileName = "myfilename.xlsx";
        string contentType = "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet";

        stream.Position = 0;
        return File(stream, contentType, fileName);
    }
}

형식 및 스타일 지정:

데이터가 로드되면 Excel을 추가로 사용자 정의하고 스타일을 지정할 수 있습니다. 범위:

var range = ws.Cells["A1"].LoadFromDataTable(table);
range.Style.Numberformat.Format = "#,##0.00"; // Set number format
range.Style.HorizontalAlignment = ExcelHorizontalAlignment.Right; // Set horizontal alignment

출력 사용자 정의:

대용량 파일을 생성할 때 잠재적인 문제를 완화하거나 중복 쓰기를 방지하려면 EPPlus에 대한 사용자 정의 FileResult 핸들러를 생성할 수 있습니다. 패키지:

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

    public ExcelPackage Package { get; private set; }

    protected override void WriteFile(HttpResponseBase response)
    {
        using (Package)
        {
            Package.SaveAs(response.OutputStream);
        }
    }
}

이 사용자 정의 결과는 컨트롤러에서 사용할 수 있습니다. action:

public FileResult ExportData()
{
    ExcelPackage package = new ExcelPackage();
    var ws = package.Workbook.Worksheets.Add("My Sheet");
    ... // Load and format data

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

이 접근 방식은 출력 스트림에 직접 쓰기를 보장하여 대용량 파일의 성능을 최적화합니다.

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

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