Создавайте, редактируйте, проверяйте, вычисляйте и экспортируйте книги Excel напрямую из кода Delphi или C++Builder. HotXLS — нативная библиотека Object Pascal с исходным кодом для рабочих процессов XLS и XLSX, предназначенная для настольных инструментов, batch-задач, систем отчетности и серверной генерации документов без автоматизации Microsoft Excel.
Эта статья предназначена для teams integrating workbook output with document management, search, audit, or customer-delivery systems. Она рассматривает workbook metadata and document properties как промышленную инженерию документов, а не как одиночный вызов компонента.
Практический риск состоит в том, что metadata is often copied from templates accidentally, causing wrong authors, stale revision labels, missing retention fields, or poor search results. Поэтому процессу нужны письменный контракт, наблюдаемая диагностика и реалистичные регрессионные файлы.
Архитектурные решения
Own metadata as delivery data. standard properties such as title, subject, author, company, category, and keywords / custom properties needed for customer, job, retention, version, or workflow state
- standard properties such as title, subject, author, company, category, and keywords
- custom properties needed for customer, job, retention, version, or workflow state
- whether metadata can expose personal data, internal IDs, or confidential notes
- revision, generated-by, and template-version strategy
Порядок реализации
Set properties from the business record. The order below keeps the workflow reviewable for Delphi and C++Builder teams.
- clear template metadata that should not reach generated output
- populate standard and custom properties from the business record
- validate required properties before saving or uploading the workbook
- include metadata in search or DMS hand-off checks
- audit final properties when support bundles are created
Доказательства проверки
Metadata evidence for document management. Keep these fields with the output or support record.
- standard property values, custom property names, and required-property status
- template version, generator version, job identifier, and retention category
- privacy review for metadata fields that may expose sensitive values
- DMS or search-index acceptance result
Workbook metadata is visible outside Excel
Document properties are consumed by search indexes, records systems, portals, DMS workflows, and support staff. They should be generated deliberately rather than inherited accidentally from a designer's template file.
Заметки по промышленной реализации
Рассматривайте HotXLS: workbook metadata and document properties in Delphi как явный сервисный контракт вокруг вызовов HotXLS, разделяя проверку входных данных, запись книги, контроль результата и сведения для поддержки
- Определите источник данных, диапазоны ячеек и формат вывода до создания книги
- Записывайте число строк, листы, предупреждения и путь вывода в проверяемые сведения поддержки
- Инкапсулируйте прикладные детали в тестируемые helper-функции, а не в события UI
- Повторно откройте или проверьте сохраненный файл перед передачей другой системе или клиенту
Сценарии отказов для проверки
- Успешный SaveAs не доказывает, что бизнес-контракт остался корректным
- Шрифты, права и региональные настройки на сервере могут отличаться от машины разработчика
- Журналы не должны раскрывать пароли, данные клиентов или внутренние ссылки
Подробный пример Delphi
Следующий пример Delphi показывает практическую границу сервиса для этой темы, где политика, журналирование и проверка остаются тестируемыми
procedure StampWorkbookMetadata(const InputFile, OutputFile: string; const Props: TWorkbookDocumentProperties);
var
Wb: TXLSXWorkbook;
Cover: IXLSWorksheet;
begin
RequireFileExists(InputFile);
Wb := TXLSXWorkbook.Create;
try
Wb.Open(InputFile);
ApplyDocumentProperties(Wb, Props);
Cover := EnsureWorksheet(Wb, 'Document Info');
Cover.Range['A1'].Value := 'Document owner';
Cover.Range['B1'].Value := Props.Owner;
Cover.Range['A2'].Value := 'Classification';
Cover.Range['B2'].Value := Props.Classification;
Cover.Range['A3'].Value := 'Retention profile';
Cover.Range['B3'].Value := Props.RetentionProfile;
Cover.Range['A1:B3'].ApplyBuiltinStyle(xbsGood);
AssertMetadataPolicy(Wb, Props);
WriteMetadataAudit(Wb, Props);
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