Teknik makale

HotXLS: data validation, AutoFilter, and worksheet tables

Excel çalışma kitaplarını doğrudan Delphi veya C++Builder kodundan oluşturun, düzenleyin, inceleyin, hesaplayın ve dışa aktarın. HotXLS; Microsoft Excel otomasyonu olmadan masaüstü araçları, batch işleri, raporlama sistemleri ve sunucu tarafı belge üretimi için tasarlanmış, XLS ve XLSX iş akışlarına yönelik kaynak kodlu yerel bir Object Pascal kütüphanesidir.

Bu yazı developers generating workbooks that users continue editing after export için hazırlanmıştır. data validation, AutoFilter, and worksheet tables konusunu tek bir bileşen çağrısı olarak değil, üretim düzeyinde belge mühendisliği olarak ele alır.

Pratik risk şudur: editable workbooks become error-prone when valid values, filters, table ranges, and totals are not generated as part of the data contract. Bu nedenle akışın yazılı sözleşmeye, gözlemlenebilir tanılara ve gerçekçi regresyon dosyalarına ihtiyacı vardır.

Mimari kararlar

Make user editing rules visible in the workbook. validation rules, allowed blank values, error messages, and list-source ownership / table range, header names, totals row, calculated columns, and naming policy

  • validation rules, allowed blank values, error messages, and list-source ownership
  • table range, header names, totals row, calculated columns, and naming policy
  • AutoFilter criteria, hidden-row behavior, and whether filters are pre-applied
  • how validation ranges expand when rows are appended by users or automation

Uygulama akışı

Build tables around validated ranges. The order below keeps the workflow reviewable for Delphi and C++Builder teams.

  1. write the data range and define headers before applying table behavior
  2. attach validation rules to user-editable cells rather than entire unused columns
  3. apply AutoFilter and totals after the final row count is known
  4. test adding rows, clearing values, sorting, and filtering in Excel
  5. record validation and table definitions for support comparison

Doğrulama kanıtı

Workbook evidence for editable deliverables. Keep these fields with the output or support record.

  • table name, range, header list, totals-row formula, and AutoFilter state
  • validation type, source range, prompt, error message, and blank-value policy
  • row count before and after user-inserted test rows
  • compatibility notes for downstream spreadsheet applications

Editing support starts before the user opens Excel

Data validation, AutoFilter, and worksheet tables help users edit data safely. They need stable ranges, clear list sources, consistent table names, and formulas that expand predictably.

Üretim uygulama notları

HotXLS: data validation, AutoFilter, and worksheet tables konusunu HotXLS çağrılarının çevresinde açık bir servis sözleşmesi olarak ele alın; giriş doğrulama, çalışma kitabı yazma, çıktı denetimi ve destek kanıtını ayırın

  • Çalışma kitabını oluşturmadan önce veri kaynağını, hücre aralıklarını ve çıktı biçimini belirleyin
  • Satır sayısı, sayfalar, uyarılar ve çıktı yolunu incelenebilir destek kaydına yazın
  • Uygulamaya özel ayrıntıları UI olaylarına değil test edilebilir helper'lara yerleştirin
  • Dosyayı başka sisteme veya müşteriye vermeden önce kaydedilmiş çıktıyı yeniden açın veya inceleyin

Prova edilmesi gereken hata kipleri

  • Başarılı SaveAs çağrısı iş sözleşmesinin doğru kaldığını kanıtlamaz
  • Sunucu ile geliştirici makinesinde yazı tipleri, izinler ve bölgesel ayarlar farklı olabilir
  • Loglar parola, müşteri verisi veya iç bağlantı açığa çıkarmamalıdır

Ayrıntılı Delphi örneği

Aşağıdaki Delphi örneği bu konu için pratik bir servis sınırı gösterir ve politika, günlükleme ve doğrulamayı test edilebilir katmanda tutar

procedure BuildValidatedOrderWorkbook(const OutputFile: string; const Rows: TArray<TOrderRow>);
var
  Wb: TXLSXWorkbook;
  Sh: IXLSWorksheet;
  RowIndex: Integer;
  Row: TOrderRow;
begin
  Wb := TXLSXWorkbook.Create;
  try
    Sh := Wb.Sheets[0];
    Sh.Name := 'Orders';
    WriteHeaderRow(Sh, ['OrderId', 'Customer', 'Status', 'Amount', 'Owner']);

    RowIndex := 2;
    for Row in Rows do
    begin
      WriteOrderRow(Sh, RowIndex, Row);
      Inc(RowIndex);
    end;

    Sh.Range['A1:E1'].ApplyBuiltinStyle(xbsTitle);
    AddListValidation(Sh, 'C2:C' + IntToStr(RowIndex - 1), ['New', 'Approved', 'Blocked']);
    AddOwnerValidation(Sh, 'E2:E' + IntToStr(RowIndex - 1));
    AddAutoFilterToHeader(Sh, 'A1:E' + IntToStr(RowIndex - 1));
    CreateStructuredTable(Sh, 'OrdersTable', 'A1:E' + IntToStr(RowIndex - 1));
    AssertValidationCoverage(Sh, RowIndex - 1);

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

Üretim kontrol listesi

  • 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