Technisch artikel

HotXLS: data validation, AutoFilter, and worksheet tables

Maak, bewerk, inspecteer, bereken en exporteer Excel-workbooks rechtstreeks vanuit Delphi- of C++Builder-code. HotXLS is een native Object Pascal-spreadsheetbibliotheek met broncode voor XLS- en XLSX-workflows, ontworpen voor desktoptools, batchtaken, rapportagesystemen en server-side documentgeneratie zonder Microsoft Excel-automatisering.

Dit artikel is bedoeld voor developers generating workbooks that users continue editing after export. Het behandelt data validation, AutoFilter, and worksheet tables als productiegerichte documentengineering, niet als een losse componentaanroep.

Het praktische risico is dat editable workbooks become error-prone when valid values, filters, table ranges, and totals are not generated as part of the data contract. Daarom heeft de workflow een geschreven contract, observeerbare diagnose en representatieve regressiebestanden nodig.

Architectuurbeslissingen

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

Implementatiepad

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

Validatiebewijs

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.

Implementatienotities voor productie

Behandel HotXLS: data validation, AutoFilter, and worksheet tables als een expliciet servicecontract rond de HotXLS-aanroepen, met gescheiden invoercontrole, werkmapopbouw, uitvoercontrole en supportbewijs

  • Leg gegevensbron, celbereiken en uitvoerformaat vast voordat de werkmap wordt gemaakt
  • Log rijenaantal, bladen, waarschuwingen en uitvoerpad in controleerbaar supportbewijs
  • Plaats applicatiespecifieke details in testbare helpers in plaats van UI-events
  • Open of inspecteer het opgeslagen bestand voordat het naar een ander systeem of klant gaat

Foutscenario's om te oefenen

  • Een geslaagde SaveAs bewijst niet dat het zakelijke contract klopt
  • Lettertypen, rechten en regionale instellingen kunnen verschillen tussen server en ontwikkelmachine
  • Logs mogen geen wachtwoorden, klantgegevens of interne links onthullen

Uitgebreid Delphi-voorbeeld

Het volgende Delphi-voorbeeld toont een praktische servicegrens voor dit onderwerp en houdt beleid, logging en validatie testbaar gescheiden

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;

Productiechecklist

  • 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