Insertion de pages complémentaires dans votre atlas
ArcGIS fournit tous les outils nécessaires pour créer des atlas imprimés ou au format PDF d'Adobe. Un atlas est un ensemble de pages imprimées ou exportées ensemble. La plupart des pages contiennent des cartes, mais d'autres pages peuvent présenter du texte, des informations tabulaires, des tables des matières ou des titres et tout autre contenu.
Un grand nombre d'atlas comprennent des documents auxiliaires, ou complémentaires. Il peut s'agir de texte de rapports, de tables, d'index et d'autres données complémentaires. Vous pouvez créer ces types d'atlas en utilisant les pages dynamiques d'ArcMap et un script Python arcpy.mapping.
L'exemple ci-dessus montre un atlas topographique d'Arenac County, dans le Michigan. Cet atlas comprend plusieurs pages complémentaires qui présentent des informations textuelles, des diagrammes et des données tabulaires. Vous pouvez créer ce document à l'aide des pages dynamiques et d'un script Python arcpy.mapping.
Pour plus d'informations, reportez-vous à la rubrique Création de pages dynamiques
Cet exemple repose sur les conditions suivantes :
- Vous disposez d'une carte existante avec des pages dynamiques.
Cet exemple de code utilise l'exemple d'atlas de référence simple figurant dans la rubrique Création d'atlas avec ArcGIS.
Vous pouvez recréer cet atlas en suivant les étapes décrites dans les rubriques d'aide suivantes : - Vous disposez de fichiers PDF contenant des rapports et des diagrammes.
- Vous disposez d'un fichier PDF existant pour la page de titre de l'atlas.
- Vous disposez d'un fichier PDF existant qui contient la page de carte globale.
Vous pouvez créer les pages de titre, de carte globale, de rapport et de diagramme à l'aide d'ArcMap. Créez simplement un contenu pour chaque page et exportez-le vers un PDF distinct pour chacune d'entre elles.
Puisque l'atlas affiche des numéros de page, vous devez vous assurer que les numéros utilisés par les pages dynamiques prennent en compte les pages complémentaires que vous insérerez dans l'atlas. Par exemple, voici une illustration de la table de couche d'indexation des pages dynamiques. PageNumber a été créé et renseigné par l'outil de géotraitement Grid_Index_Features lorsque la grille a été créée. Ces numéros de page ne seront pas corrects puisque vous souhaitez insérer des pages entre les différentes pages de cartes. Un nouveau champ doit être créé pour les numéros de page et les valeurs doivent être renseignées en conséquence. Ici un nouveau champ, NewPageNum, a été créé et renseigné avec des valeurs qui prennent en compte les pages à insérer.
Assurez-vous que vous choisissez le champ approprié pour les numéros de page avant de créer les pages dynamiques.
Assurez-vous également que vous utilisez les éléments de texte corrects si vous affichez le numéro de page. Vous ne devez pas utiliser Page dynamique avec numéro, car le total correspond uniquement au nombre total de pages dynamiques. Il ne comprend pas les autres pages, telles que les pages de titre ou de rapport, que vous incorporerez à l'atlas final. A la place utilisez, Numéro de la page dynamique et combinez ce texte dynamique avec le texte statique qui affiche le nombre total de pages, par exemple, Page <dyn type="page" property="number"/> of 26.
Une fois que votre carte et vos fichiers PDF sont prêts, vous pouvez exécuter le code ci-dessous pour créer votre atlas final au format PDF. Vous pouvez exécuter le code dans la fenêtre Python ou dans une application Python autonome.
Bien que le code spécifique de cette rubrique s'applique à l'exemple d'atlas ci-dessus, vous pouvez également utiliser les procédures et les conseils présentés ici pour vos propres cartes et atlas.
Insérez des pages complémentaires dans un atlas au format PDF.
import arcpy, os
# Create an output location variable
outDir = r"C:\temp\MBExample\final_output"
# Create a new, empty pdf document in the specified output location folder
finalpdf_filename = outDir + r"\ArenacMB.pdf"
if os.path.exists(finalpdf_filename):
os.remove(finalpdf_filename)
finalPdf = arcpy.mapping.PDFDocumentCreate(finalpdf_filename)
# Add the title page to the pdf
finalPdf.appendPages(r"C:\temp\MBExample\ancillary_pages\TitlePage.pdf")
# Add the overview map to the pdf
finalPdf.appendPages(r"C:\temp\MBExample\maps\IndexMap.pdf")
# Export the Data Driven Pages to a temporary pdf and then add it to the
# final pdf. Alternately, if your Data Driven Pages have already been
# exported, simply append that document to the final pdf.
#
mxdPath = r"C:\temp\MBExample\maps\ArenacDDP Reports.mxd"
tempMap = arcpy.mapping.MapDocument(mxdPath)
tempDDP = tempMap.dataDrivenPages
temp_filename = r"C:\temp\MBExample\temp_pdfs\tempDDP.pdf"
if os.path.exists(temp_filename):
os.remove(temp_filename)
tempDDP.exportToPDF(temp_filename, "ALL")
finalPdf.appendPages(temp_filename)
# Insert the pdf pages containing the reports and graphs into the final pdf
#
finalPdf.insertPages(r"C:\temp\MBExample\ancillary_pages\Report_pg4.pdf", 4)
finalPdf.insertPages(r"C:\temp\MBExample\ancillary_pages\Report_pg5.pdf", 5)
finalPdf.insertPages(r"C:\temp\MBExample\ancillary_pages\Report_pg7.pdf", 7)
# Update the properties of the final pdf
finalPdf.updateDocProperties(pdf_open_view="USE_THUMBS",
pdf_layout="SINGLE_PAGE")
# Save your result
finalPdf.saveAndClose()
# Delete variables
del finalPdf
Les premières lignes de code permettent d'effectuer les opérations suivantes : importer les modules nécessaires ; créer une variable d'emplacement des données en sortie où l'atlas final au format PDF sera enregistré ; créer un nouveau document PDF vide dans le dossier d'emplacement des données de sortie spécifié. Ce PDF est le document de sortie final pour ce script.
Les langages de programmation, tels que Python, traitent une barre oblique inverse (\) en tant que caractère d'échappement. Par exemple, \n représente un saut de ligne et \t représente une tabulation. Lorsque vous spécifiez un chemin d'accès, vous pouvez utiliser une barre oblique (/) à la place d'une barre oblique inverse. Deux barres obliques inverses peuvent être utilisées au lieu d'une pour éviter une erreur de syntaxe. Un littéral de chaîne peut être également utilisé en plaçant la lettre r avant une chaîne contenant une barre oblique inverse afin de l'interpréter correctement.
Pour plus d'informations, reportez-vous à la rubrique Classe PDFDocument d'arcpy.mapping.
Les lignes de code suivantes ajoutent la page de titre et la page de carte globale au PDF final. Cet exemple suppose que vous disposez de documents PDF existants pouvant être utilisés pour les pages de titre et de carte globale.
L'étape suivante consiste à ajouter les pages de carte. Cela nécessite que vous ayez une carte dont l'option Pages dynamiques est déjà activée. Dans cet exemple, ce document ArcMap s'appelle ArenacDDP Reports.
Pour plus d'informations, reportez-vous aux rubriques Classe MapDocument et Classe DataDrivenPages d'arcpy.mapping.
Ensuite, insérez les pages au format PDF contenant les rapports et diagrammes dans le PDF final.
Enfin, le code met à jour les propriétés, puis enregistre et ferme le PDF final.