Создавайте, редактируйте, проверяйте, вычисляйте и экспортируйте книги Excel напрямую из кода Delphi или C++Builder. HotXLS — нативная библиотека Object Pascal с исходным кодом для рабочих процессов XLS и XLSX, предназначенная для настольных инструментов, batch-задач, систем отчетности и серверной генерации документов без автоматизации Microsoft Excel.
Эта статья предназначена для developers generating workbooks that users continue editing after export. Она рассматривает data validation, AutoFilter, and worksheet tables как промышленную инженерию документов, а не как одиночный вызов компонента.
Практический риск состоит в том, что editable workbooks become error-prone when valid values, filters, table ranges, and totals are not generated as part of the data contract. Поэтому процессу нужны письменный контракт, наблюдаемая диагностика и реалистичные регрессионные файлы.
Архитектурные решения
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
Порядок реализации
Build tables around validated ranges. The order below keeps the workflow reviewable for Delphi and C++Builder teams.
- write the data range and define headers before applying table behavior
- attach validation rules to user-editable cells rather than entire unused columns
- apply AutoFilter and totals after the final row count is known
- test adding rows, clearing values, sorting, and filtering in Excel
- record validation and table definitions for support comparison
Доказательства проверки
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.
Заметки по промышленной реализации
Рассматривайте HotXLS: data validation, AutoFilter, and worksheet tables как явный сервисный контракт вокруг вызовов HotXLS, разделяя проверку входных данных, запись книги, контроль результата и сведения для поддержки
- Определите источник данных, диапазоны ячеек и формат вывода до создания книги
- Записывайте число строк, листы, предупреждения и путь вывода в проверяемые сведения поддержки
- Инкапсулируйте прикладные детали в тестируемые helper-функции, а не в события UI
- Повторно откройте или проверьте сохраненный файл перед передачей другой системе или клиенту
Сценарии отказов для проверки
- Успешный SaveAs не доказывает, что бизнес-контракт остался корректным
- Шрифты, права и региональные настройки на сервере могут отличаться от машины разработчика
- Журналы не должны раскрывать пароли, данные клиентов или внутренние ссылки
Подробный пример Delphi
Следующий пример Delphi показывает практическую границу сервиса для этой темы, где политика, журналирование и проверка остаются тестируемыми
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;
Производственный чек-лист
- 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