В этом примере показано, как задать ширины столбцов для DOM Table
и FormalTable
.
Импортируйте пакет DOM API, чтобы не использовать длинные, полные имена классов.
import mlreportgen.dom.*
Создание и открытие документа. Чтобы создать документ Word, измените тип выхода с pdf
на docx
. Чтобы создать HTML, измените pdf
на html
или html-file
для мультифайла или однофайлового документа, соответственно.
d = Document("mydoc","pdf"); открытый (d);
Задайте таблицы, записи таблицы и стили строк заголовков, которые будут использоваться в последующих разделах.
tableStyle = ... { ... Width("100%"), ... Border("solid"), ... RowSep("solid"), ... ColSep("solid") ... }; tableEntriesStyle = ... { ... HAlign("center"), ... VAlign("middle") ... }; headerRowStyle = ... { ... InnerMargin("2pt","2pt","2pt","2pt"), ... BackgroundColor("gray"), ... Bold(true) ... };
Определите содержимое для строки заголовка таблицы и тела таблицы, которое будет использовано позже для создания трехколоночного DOM- Table
и a FormalTable
.
headerContent = ... { ... 'First Name', 'Last Name', 'Address' ... }; bodyContent = ... { ... 'John', 'Smith', 'Natick, MA'; ... 'Jane', 'Doe', 'Boston, MA'; ... 'Robert', 'Stewart', 'Natick, MA' ... };
Следующий код использует DOM TableColSpecGroup
для определения стилей для группы столбцов в таблице. Установка Span
свойство к 3
применяет форматирование группы ко всем трем столбцам таблицы. Для форматирования одного или нескольких соседних столбцов таблицы в группе используйте DOM TableColSpec
объекты. Первый TableColSpec
объект, specs(1)
, переходит к первому 2
столбцы в группе. Установите Width
формат в его Style
свойство, чтобы сделать каждый из этих двух столбцов 20%
ширины таблицы. Вторая TableColSpec
объект, specs(2)
, охватывает один столбец, то есть третий столбец в группе, и форматируется, чтобы быть 60%
ширины таблицы.
grps(1) = TableColSpecGroup; grps(1).Span = 3; specs(1) = TableColSpec; specs(1).Span = 2; specs(1).Style = {Width("20%")}; specs(2) = TableColSpec; specs(2).Span = 1; specs(2).Style = {Width("60%")}; grps(1).ColSpecs = specs;
Следующий код добавляет заголовок и DOM Table
к документу. Назначение grps
, созданный в вышеуказанном коде, в ColSpecGroups
свойство таблицы, делает первые 2 столбца 20% и третий столбец 60% ширины таблицы. Код также присваивает стили для таблицы, записей таблицы и первой строки таблицы.
append(d,Heading1("Set column width for a DOM Table"));
tableContent = [headerContent; bodyContent];
table = Table(tableContent);
table.ColSpecGroups = grps;
table.Style = tableStyle;
table.TableEntriesStyle = tableEntriesStyle;
firstRow = table.Children(1);
firstRow.Style = headerRowStyle;
append(d,table);
Следующий код добавляет заголовок и DOM FormalTable
к документу. Назначение grps
на ColSpecGroups
свойство формальной таблицы делает первые 2 столбца 20% и третий столбец 60% ширины таблицы. Код также присваивает стили для формальной таблицы, записей таблицы и строки заголовка формальной таблицы.
append(d,Heading1("Set column width for a DOM FormalTable"));
formalTable = FormalTable(headerContent,bodyContent);
formalTable.ColSpecGroups = grps;
formalTable.Style = tableStyle;
formalTable.TableEntriesStyle = tableEntriesStyle;
headerRow = formalTable.Header.Children;
headerRow.Style = headerRowStyle;
append(d,formalTable);
Закройте и просмотрите документ.
close(d); rptview(d);