기술 문서

HotXLS Component: Delphi에서 large workbook performance

Delphi 또는 C++Builder 코드에서 Excel 통합 문서를 직접 생성, 편집, 검사, 계산, 내보낼 수 있습니다. HotXLS는 소스 코드가 포함된 네이티브 Object Pascal 스프레드시트 라이브러리로 XLS 및 XLSX 워크플로, 데스크톱 도구, 배치 작업, 보고 시스템, Microsoft Excel 자동화 없는 서버 문서 생성에 적합합니다.

이 글은 teams generating or processing large XLS/XLSX workbooks in desktop utilities, services, or batch jobs을 위한 글입니다. large workbook performance을 단순한 컴포넌트 호출이 아니라 운영 환경의 문서 엔지니어링으로 다룹니다.

실제 위험은 large-workbook workflows fail when shared strings, styles, formulas, memory buffers, and output streams are not managed as production resources입니다. 따라서 명확한 계약, 관찰 가능한 진단, 실제 고객 파일을 반영한 회귀 샘플이 필요합니다.

아키텍처 결정

Plan memory, styles, and streaming together. maximum row count, column count, sheet count, and output file size / shared-string strategy, style reuse, formula volume, and image policy

  • maximum row count, column count, sheet count, and output file size
  • shared-string strategy, style reuse, formula volume, and image policy
  • streaming write boundaries, temporary storage, progress, and cancellation
  • Excel compatibility limits and downstream import limits

구현 흐름

Measure workbook size during generation. The order below keeps the workflow reviewable for Delphi and C++Builder teams.

  1. create capacity fixtures that represent real customer data distribution
  2. reuse styles and strings instead of generating unique resources per cell
  3. write rows in controlled batches and flush output only at safe boundaries
  4. track memory, elapsed time, file size, and warning counts per stage
  5. open large output with the target application before increasing limits

검증 증거

Performance evidence for capacity planning. Keep these fields with the output or support record.

  • row count, column count, sheet count, style count, shared-string count, and file size
  • memory peak, elapsed time, batch size, temporary storage, and cancellation result
  • formula count, image count, comment count, and relationship count
  • target Excel or importer open time for representative output

Rows are not the only scale factor

Workbook size grows with cells, styles, shared strings, formulas, images, comments, and relationships. A performance plan should reduce redundant resources and choose streaming only where it fits the output contract.

운영 구현 메모

HotXLS Component: Delphi에서 large workbook performance 작업은 HotXLS 호출 주변의 명확한 서비스 계약으로 다루고, 입력 검증, 통합 문서 작성, 출력 확인, 지원 증거를 분리해야 합니다

  • 통합 문서를 만들기 전에 데이터 원본, 셀 범위, 출력 형식을 확정합니다
  • 행 수, 시트 수, 경고, 출력 경로를 검토 가능한 지원 기록으로 남깁니다
  • 애플리케이션 세부 처리는 UI 이벤트가 아니라 테스트 가능한 helper에 둡니다
  • 다른 시스템이나 고객에게 전달하기 전에 저장된 파일을 다시 열거나 검사합니다

반드시 재현해 볼 실패 모드

  • SaveAs 성공만으로 업무 계약이 맞다는 뜻은 아닙니다
  • 서버와 개발 PC의 글꼴, 권한, 지역 설정은 다를 수 있습니다
  • 로그에는 암호, 고객 데이터, 내부 링크가 노출되면 안 됩니다

자세한 Delphi 예제

다음 Delphi 예제는 이 주제의 실용적인 서비스 경계를 보여 주며, 정책, 로깅, 검증을 테스트 가능한 계층에 둡니다

procedure WriteLargeLedgerWorkbook(const OutputFile: string; const Source: ILedgerReader);
var
  Wb: TXLSXWorkbook;
  Sh: IXLSWorksheet;
  RowIndex: Integer;
  Batch: TArray<TLedgerRow>;
  Item: TLedgerRow;
  Metrics: TWorkbookMetrics;
begin
  Wb := TXLSXWorkbook.Create;
  try
    Sh := Wb.Sheets[0];
    Sh.Name := 'Ledger';
    WriteHeaderRow(Sh, ['Account', 'Date', 'Description', 'Debit', 'Credit', 'Balance']);
    RowIndex := 2;
    Metrics := StartWorkbookMetrics('large-ledger');

    repeat
      Batch := Source.ReadNextBatch(5000);
      for Item in Batch do
      begin
        WriteLedgerRow(Sh, RowIndex, Item);
        Inc(RowIndex);
      end;
      CheckMemoryAndTempQuota(Metrics, RowIndex - 2);
      FlushProgressMetric(Metrics, RowIndex - 2);
    until Length(Batch) = 0;

    Sh.Range['A1:F1'].ApplyBuiltinStyle(xbsTitle);
    AddSummarySheet(Wb, Metrics, RowIndex - 2);
    AssertWorkbookSizePolicy(OutputFile, RowIndex - 2);

    if Wb.SaveAs(OutputFile) <> 1 then
      RaiseWorkbookSaveError(OutputFile);
  finally
    Wb.Free;
  end;
end;

운영 체크리스트

  • Run the workflow on an empty workbook, a normal customer workbook, and a worst-case workbook
  • Open the output with the target spreadsheet application or downstream importer
  • Log product version, template version, profile, row count, output path, elapsed time, and warning count
  • Keep passwords, temporary files, customer data, and support bundles under explicit retention rules
  • Add regression workbooks when a customer file exposes a new edge case

Product documentation

HotXLS Component