Номерные страницы в шаблоне PDF

В этом примере показано, как нумеровать страницы отчета с помощью шаблона PDF. Он задает выровненный по правому краю номер страницы для нечетных страниц и выровненный по левому краю номер страницы для четных страниц с помощью двух разных нижних колонтитулов. На следующем изображении показаны две страницы документа, созданные с использованием шаблона примера:

Создание шаблона

Создайте PDF шаблона, myPDFTemplate.pdftx, в текущей рабочей директории. Разархивируйте шаблон для редактирования. Ссылка шаблона, которая уже включает нижние колонтитулы для примера, доступна в exampleTemplate.pdftx.

mlreportgen.dom.Document.createTemplate("myPDFTemplate","pdf");
unzipTemplate("myPDFTemplate.pdftx", "myPDFTemplate_pdftx");
%unzipTemplate("exampleTemplate.pdftxt", "exampleTemplate_pdftx");

Задайте содержимое нижнего колонтитула

В myPDFTemplate_pdftx\docpart_templates.htmlзадайте детали шаблона, которые содержат содержимое нижних колонтитулов. В <dplibrary> теги, создание <dptemplate> элементы с именем MyPageFooter для нечетных страниц и MyEvenFooter для четных страниц. Создайте абзацы, которые содержат текст, включенный в каждый нижний колонтитул, а также page элементы, в которых должен быть размещен номер страницы. Установите text-align стиль в right для MyPageFooter и left для MyEvenFooter. Для примера:

<dplibrary>
    <dptemplate name="rgChapter">
        <h1 class="rgChapterTitle">
        <hole id="rgChapterTitlePrefix" default-style-name="rgChapterTitlePrefix" /><span> </span>  
        <hole id="rgChapterTitleNumber" default-style-name="rgChapterTitleNumber" /><span>. </span>
        <hole id="rgChapterTitleText" default-style-name="rgChapterTitleText" />
        </h1>
        <hole id="rgChapterContent"/>
    </dptemplate>
    <dptemplate name="ReportTOC"><TOC number-of-levels ="3" leader-pattern="dots" /></dptemplate>
    
    <!-- Document part templates defining the footers -->
    <dptemplate name="MyPageFooter">
        <p style="text-align:right;font-size:10pt;white-space:preserve">Page <page/></p>
    </dptemplate>
    
    <dptemplate name="MyEvenFooter">
        <p style="text-align:left;font-size:10pt;white-space:preserve">Page <page/></p>
    </dptemplate>    
</dplibrary>

Создание элементов нижнего колонтитула

В разделе тела myPDFTemplate_pdftx\root.html, раскомментируйте <layout> элемент и добавить два <pfooter> элементы. Установите type и template-name атрибуты, как показано в следующем примере HTML кода. The default нижний колонтитул типа используется для первых и нечетных страниц. The even нижний колонтитул типа используется для четных страниц. The template-name для атрибутов заданы имена деталей шаблона, заданные ранее. Чтобы указать номер начальной страницы, добавьте <pnumber> элемент.

<html>
<head>
    <meta charset="utf-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <title>Report Template</title>
    <link rel="StyleSheet" href="./stylesheets/root.css" type="text/css" />
</head>

<body>
    
<!-- Uncomment and edit this layout to customize a document or document part layout based on this template. -->
<layout style="page-margin: 1in 1in 1in 1in 0.5in 0.5in 0in; page-size: 8.5in 11in portrait">
    <pfooter type="default" template-name="MyPageFooter"/>
    <pfooter type="even" template-name="MyEvenFooter"/>
    <pnumber format="1" />
</layout>

</body>
</html>

ZIP шаблон

Заархивируйте файлы шаблона назад в myPDFTemplate.pdftx пакет шаблона.

zipTemplate('myPDFTemplate.pdftx', 'myPDFTemplate_pdftx');

Использование шаблона

Используйте шаблон путем определения имени шаблона при создании документа. Следующий код использует шаблон ссылки exampleTemplate.pdftx для создания документа. Чтобы использовать шаблон, измененный примером, замените exampleTemplate с myPDFTemplate.

import mlreportgen.dom.*

d = Document("myDocument", "pdf", "exampleTemplate");
open(d);

append(d, "Hello world");
append(d, PageBreak());
append(d, "Hello again");
append(d, PageBreak());
append(d, "Hello again");
append(d, PageBreak());
append(d, "Hello again");
append(d, PageBreak());
append(d, "Hello again");

close(d);
rptview(d);

См. также

Похожие темы