Posts Tagged ‘style’

Ajouter des liens hypertextes dans vos fichiers PDF
octobre 4, 2009Dans cet article, je vous propose d’ajouter des liens hypertextes dans vos fichiers .PDF créés avec la syntaxe de l’ODS PDF. Pour illustrer ce sujet, nous créerons une table des matières (table of contents ou TOC) rustique avec ODS PDF TEXT=’ ‘; où il suffira de cliquer sur la section qui vous intéresse pour l’atteindre.
1. Le principe de base
Pour ajouter des liens hypertextes, il faut deux informations :
- la location du point d’encrage/de destination (anchor)
- le lien vers ce point d’encrage
ods escapechar=‘^’;
ods listing close;
ods pdf file=‘C:/sasref/hyperlink_toc.pdf’;
ods pdf text=‘Table of Contents’;
ods pdf text= »;
ods pdf text=‘^S={url=’#hommes’}1. Hommes’;
ods pdf text=‘^S={url=’#femmes’}2. Femmes’;
ods pdf anchor=‘hommes’;
ods pdf text=‘1. Hommes’;
proc print data=sashelp.class(where=(sex=‘M’));
run;
ods pdf anchor=‘femmes’;
ods pdf text=‘2. Femmes’;
proc print data=sashelp.class(where=(sex=‘F’));
run;
ods pdf close;
ods listing;
Le point d’encrage : Le point d’encrage est donné par l’instruction ods pdf anchor=‘…’;. Entre guillemets est donné un nom de votre choix qui servira à l’identifier.
Le lien hypertexte : Le lien vers ce point d’encrage est donné par le mot URL à préciser sous forme de style donné au texte sur lequel cliquer.
ods pdf text=‘^S={url=’#…’}Je clique ici’;
Définition d’un style : Le style est défini avant le texte par S={…}. Pour indiquer à SAS qu’il faille interpréter ce texte comme un style et non un texte brut, un caractère doit précédé le tout. J’ai choisi le symbole du chapeau défini auparavant avec l’instruction ods escapechar=‘^’;
2. Personnaliser le style
Supprimer l’affichage du bookmark : Dans la version enrichie qui suit, j’ai choisi l’option NOTOC pour éviter l’affichage du bookmark sur la gauche de l’écran propre aux fichier PDF.
Les sauts de pages à la demande: J’ai aussi choisi d’enlever par défaut tous les sauts de pages ods pdf startpage=never; puis d’ajouter une fois un saut de page entre la table des matières et les tableaux avec ods pdf startpage=now;
Les en-têtes en moins : Le titre par défaut, la date et le numéro des pages sont enlevés :
title;
options nodate nonumber;
Les liens hypertextes invisibles : Par défaut, le lien hypertexte est présenté par un cadre bleu autour du texte à cliquer. Pour enlever ce cadre, travaillez le style avec ACTIVELINKCOLOR, VISITEDLINKCOLOR et LINKCOLOR.
ods pdf text=« ^S={activelinkcolor=white
visitedlinkcolor=white
linkcolor=white
url=’…’}… »;
D’autres styles permettent ici d’affiner la présentation :
- VJUST : ajustement vertical du texte
- CELLHEIGHT : hauteur de la case contenant le texte
- CELLWIDTH : largeur de la case contenant le texte
- FONT_FACE : la police de style
- FONT_SIZE : la taille du texte
- INDENT : l’indentation du texte
- FONT_WEIGHT : mise en gras du texte
J’ai choisi de sauvegarder ces informations dans des macros variables pour pouvoir centraliser l’information en début de programme.
3. Le résultat
Deux pages sont donc créées. La première contient la table des matières. Vous pouvez cliquer sur le texte 1. Hommes ou 2. Femmes pour rejoindre le tableau qui vous intéresse.
Annexe : l’intégralité du code
%let titl=vjust=middle
cellheight=30pt
cellwidth=17cm
font_face=arial
activelinkcolor=white
visitedlinkcolor=white
linkcolor=white;
%let titl1=&titl indent=5cm font_size=16pt font_weight=bold;
%let titl2=&titl indent=6cm font_size=12pt;
title;
options nonumber nodate;
ods escapechar=’^’;
ods listing close;
ods pdf file=‘C:/sasref/hyperlink_toc.pdf’ notoc startpage=never;
ods pdf text=« ^S={&titl1.}Table of Contents »;
ods pdf text= »;
ods pdf text=« ^S={&titl2. url=’#hommes’}1. Hommes »;
ods pdf text=« ^S={&titl2. url=’#femmes’}2. Femmes »;
ods pdf startpage=now;
ods pdf anchor=‘hommes’;
ods pdf text=« ^S={&titl2.}1. Hommes »;
proc print data=sashelp.class(where=(sex=‘M’));
run;
ods pdf anchor=‘femmes’;
ods pdf text=« ^S={&titl2.}2. Femmes »;
proc print data=sashelp.class(where=(sex=‘F’));
run;
ods pdf close;
ods listing;

Passer par un format pour changer les couleurs d’une cellule dans un tableau (PROC REPORT et ODS)
septembre 17, 2009Dans de précédents articles, je vous ai parlé de la possibilité de changer le style des cellules d’un tableau. Je vous invite ici à découvrir comment un format peut vous éviter de passer par un COMPUTE/ENDCOMP de PROC REPORT pour changer le style selon les valeurs prises par une variable donnée.
1. Créer les formats pour l’exemple
Pour mettre en gras (bold) ou non, il faut passer par le style FONT_WEIGHT. Dans notre exemple, ce style prendra la valeur BOLD quand la variable AGE aura des valeurs entre 14 et 16 ans et un LIGHT pour un style non gras. Vous avez aussi à disposition la valeur MEDIUM pour un ton légèrement plus prononcé.
Pour changer la couleur du texte, c’est le style FOREGROUND qu’il faut utiliser. Dans notre cas, le texte aura la couleur bleu si la variable AGE est comprise entre 14 et 16 ans inclus.
proc format;
value age_font 11–13=‘light’
14–16=‘bold’;
value age_color 14–16=‘blue’;
run;
2. Utiliser le format dans PROC REPORT
Pour changer le style d’une colonne en particulier, il suffit d’ajouter style(column)=[…] dans l’instruction DEFINE.
Ici au lieu de donner une couleur à toutes les valeurs avec FOREGROUND= suivi du nom de la couleur, on donne le format AGE_COLOR. qui prendra la valeur BLUE pour les AGE des 14-16 ans.
De manière similaire, l’épaisseur du trait est changée avec FONT_WEIGHT et le format AGE_FONT. défini auparavant.
ods listing close;
ods pdf file=‘C:/sasref/zebre.pdf’;
proc report data=sashelp.class nowd;
columns name age;
define name / display ;
define age / display style(column)=[font_weight=age_font. foreground=age_color.];
run;
ods pdf close;
ods listing;
3. Voir le résultat
Lectures complémentaires
- Alterner les couleurs de fond dans un tableau : une ligne sur deux (PROC REPORT et ODS)
- Changer la couleur d’une ligne ou d’une colonne grâce à PROC REPORT et ODS
- Un moyen simple de changer les couleurs en fonction des valeurs prises par des variables dans un fichier .xls
- Choisir ses couleurs sous SAS
Des questions ? Envoyez votre message sur le forum du blog.

Mes 1ers pas avec ODS TAGSETS.EXCELXP (2/3)
mai 19, 2008Sous SAS, l’ODS TAGSETS.EXCELXP est une alternative au PROC EXPORT. Dans une première partie, vous avez vu comment modifier la largeur d’une colonne, gérer l’alignement des valeurs textes et former une cellule unique servant de titre à plusieurs colonnes, le tout avec la syntaxe de proc report. Maintenant vous allez découvrir comment modifier les couleurs, polices de caractères, etc. en créant un nouveau template.
1. La structure de base de PROC TEMPLATE
Une autre particularité que l’on rencontrera dans le fichier Excel, c’est la présence de la couleur grise pour le fond ces cellules ayant des données, une couleur bleuté pour le texte des cellules contenant le nom des variables, etc.
Pour altérer ces couleurs, disons remettre du blanc en fond et du texte en noir, on va créer un nouveau template à partir d’un existant. Il suffira alors de modifier les quelques paramètres qui nous intéresse.
La structure de base du PROC TEMPLATE est la suivante :
proc template;
define style styles.vero_xls;
parent=style.default;
*style x from x /…;
run;
J’ai donné le nom vero_xls à ce nouveau STYLE. Vous pouvez choisir le nom qui vous plaira. L’important est de se référer au même nom par la suite.
2. Les instructions STYLE de PROC TEMPLATE
Il existe plusieurs instructions STYLE, selon qu’il s’agisse :
- de la partie non couverte par les données : style Table from Table
- de la partie couverte par les noms de colonnes : style Header from Header
- de la partie couverte par le nom des lignes (dans un proc print, les valeurs de la variable obs) : style RowHeader from RowHeader
- de la partie couverte par les données : style Data from Data
- de l’apparence de la page A4 d’impression : style Body from Body
Voicic trois autres styles :
- style SystemTitle from SystemTitle /…;
- style SystemFooter from SystemFooter /…;
- style SysTitleAndFooterContainer from SysTitleAndFooterContainer /…;
3. Les options des instructions STYLE
Les options sont situées après la barre inclinée (slash /). Les valeurs prises par ces options sont notées entre guillemets.
Les options les plus courantes sont :
- FOREGROUND = (couleur du texte). Ici, on choisira le mot ‘black’ entre guillemets.
- BACKGROUND = (couleur des cellules). Ici, on choisira ‘white’.
- FONT_SIZE = (la taille du texte). Ici, on choisira 1.5 par exemple.
- FONT_FACE = (la ou les polices de caractères). Ici, on choisi ‘Courier’. Mais on peut aussi opter pour ‘Courier,Arial’. Ainsi si la police Courier n’est pas disponible, Arial sera le second choix.
Deux autres options du langage courant
- FONT_WEIGHT= (mette en gras). La valeur BOLD sert à mettre en gras
- FONT_STYLE= (mettre en italique ou non). La valeur ITALIC met en italique tandis que ROMAN fait l’inverse.
Agir dur les bordures des cellules :
- BORDER_COLOR= (couleur de la bordure)
- BORDER_WIDTH= (largeur de la bordure)
Agir sur les marges du document A4.
- LEFTMARGIN = (marge de gauche)
- RIGHTMARGIN = (marge de droite)
- TOPMARGIN = (marge du haut)
- BOTTOMMARGIN = (marge du bas)
Note : Une liste des différents styles est disponible sur ce forum : http://www.tek-tips.com/viewthread.cfm?qid=1178234&page=1.
4. Faire référence au nouveau template
Pour que ce template soit lu à la place de celui par défaut, on ajoutera STYLE=nom_du_nouveau_template dans l’instruction ODS TAGSETS.EXCELXP de début.
ods tagsets.excelxp file = ‘C:/excel/mon_nouveau_fichier.xls’
style = vero_xls;
proc report …;
run;
ods tagsets.excelxp close;
Après avoir vu les actions menées au niveau du PROC REPORT et du PROC TEMPLATE pour personnaliser son fichier Excel, vous verrez dans le troisième et dernier article sur « Mes premiers pas avec ODS TAGSETS.EXCELXP », lundi prochain, les options disponibles dans l’instruction ODS.