Archive for the ‘SAS intermédiaire’ Category

A partir de quelle lettre y a-t-il une différence : la fonction compare
mai 25, 2015La fonction COMPARE retourne le nombre zéro si aucune différence n’existe entre deux chaînes de caractères. Sinon elle retourne la position la position du premier caractère différent.
Dans l’exemple ci-dessous, deux datasets sont créés. Une fois combinés, on s’intéresse à la différence entre la variable LABEL_ONE du premier dataset et la variable LABEL_TWO du second dataset. La première différence a lieu sur la deuxième lettre. La variable DIFF prend donc la valeur 2.
data one;
length start $8 label_one $8;
start='1';
label_one='ABC';
run;
data two;
length start $8 label_two $8;
start='1';
label_two='AbC';
run;
data diff;
merge one two;
by start;
run;
data diff;
set diff;
diff=compare(label_one,label_two);
run;
proc print data=diff;
run;
Vous pouvez ajouter un troisième paramètre dans la fonction si vous ne voulez pas tenir compte des différences de majuscule, de blancs de début de chaîne de caractère,…
Dans quel cas utiliser cette fonction ? Si vous réalisez un rapport listant la différence entre deux valeurs pour pouvoir ensuite les corriger, vous pouvez utiliser cette fonction pour préciser à partir de quel moment la couleur devra changer.
Pour en savoir plus : la documentation SAS 9.2

André Wiekli : ouvrage gratuit sur SAS 9.2 à télécharger
août 28, 2011Téléchargez ici l’ouvrage gratuit d’André Wielki sur SAS 9.2 sous Windows. Il est composé de 10 chapitres répartis en 4 parties soit 215 pages d’information destinées à des initiés ou des débutants très motivés.
Ici vous avez dans un .pdf l’intégralité du livre. Vous pouvez opter pour un .pdf par partie ou encore un .pdf par chapitre. En fin de post, il est possible de visionner l’ouvrage complet sans téléchargement.
1. La table des matières
TdM Couverture et avant propos, Table des matières, 10 pages
Partie 1 Le Fonctionnement en SAS Fenêtre de SAS Windows, 64 pages
- Chapitre 1 Introduction à l’interface SAS Windows, 6 pages
- Chapitre 2 SAS Windows quelques repères techniques cachés, 18 pages
- Chapitre 3, Familiarisation avec des fenêtres de SAS Windows : l’espace de travail SAS (AWS) et son architecture interne, 24 pages
- Chapitre 4 Familiarisation avec des fenêtres de SAS Windows (suite), 14 pages
Partie 2 Thèmes particulier concernant SAS Windows, 44 pages
- Chapitre 5, La version 9.2… Windows avec les autres versions de SAS, 6 pages
- Chapitre 6 Les liens micros-host, 12 pages
- Chapitre 7 Les échanges des tables SAS avec d’autres logiciels micros, 23 pages
Partie 3 Les Sorties/Résultats SAS Impression et ODS, 67 pages
- Chapitre 8 Les sorties imprimées classiques (texte ou graphique), 4 pages
- Chapitre 9 La voie royale de l’ODS (Output Delivery System), 61 pages
Partie 4 Divers changements dans le langage SAS de Base, 24 pages
- Chapitre 10 Panorama des changements du langage SAS 9.2.3, 23 pages
Annexe A Visualisation d’une table SAS, 6 pages
2. Les téléchargements
Télécharger l’intégralité du document :
Wielki_SAS92_10_integralite.pdf, 215 pages (table des matières en fin de document)
Télécharger chacune des 4 parties
Wielki_SAS92_21-couverture-tabledesmatieres.pdf, 10 pages
Wielki_SAS92_22_partie1.pdf, 64 pages
Wielki_SAS92_22_partie2.pdf, 44 pages
Wielki_SAS92_22_partie3.pdf, 67 pages
Wielki_SAS92_22_partie4.pdf, 24 pages
Wielki_SAS92_23_annexe.pdf, 6 pages
Télécharger chacun des 10 chapitres
Wielki_SAS92_31-couverture-tabledesmatieres.pdf, 10 pages
Wielki_SAS92_32-chapitre01.pdf, 6 pages
Wielki_SAS92_32-chapitre02.pdf, 18 pages
Wielki_SAS92_32-chapitre03.pdf, 24 pages
Wielki_SAS92_32-chapitre04.pdf, 14 pages
Wielki_SAS92_32-chapitre05.pdf, 6 pages
Wielki_SAS92_32-chapitre06.pdf, 12 pages
Wielki_SAS92_32-chapitre07.pdf, 23 pages
Wielki_SAS92_32-chapitre08.pdf, 4 pages
Wielki_SAS92_32-chapitre09.pdf, 61 pages
Wielki_SAS92_32-chapitre10.pdf, 23 pages
Wielki_SAS92_33_annexe.pdf, 6 pages
3. L’intégralité de l’ouvrage
Notez que la table des matières est en fin d’ouvrage.

Protégé : Plusieurs formats pour une variable numériques – passer à une variable caractère avec la fonction PUTN
octobre 14, 2010
Protégé : Une option SAS 9.2 pour ODS PDF : répéter une valeur groupée sur plusieurs pages
août 3, 2010
Structurer ses travaux à l’aide de pages HTML
juillet 25, 2010Joël Rivest a eu l’occasion de présenter quelques usages du HTML pour structurer ses travaux SAS lors d’une rencontre sur la ville de Québec en juin dernier. Voici le support utilisé pour cette intervention. Vous y découvrirez comme sujet : 2 modes d’utilisation du HTML, quelques avantages que présentent le HTML, quelques pré-requis, quelques macros pour faciliter l’écriture des résultats dans des pages web.
Vous souhaitez télécharger la présentation grand format ici : Joel_Rivest_Structurer_travaux_SAS_via_ pages_HTML.ppt
Quelques abréviations:
OLE : Object Linking and Embedding (définition de Wikipédia)
Cie : Compagnie

Une petite histoire de macro : compter le nombre de mots dans un paramètre de macro
avril 11, 2010Il est courant de devoir compter le nombre de mots dans un paramètre de macro. Il est par exemple possible de vouloir créer une boucle pour travailler chacun des termes contenu dans cette macro de manière séparée.
Voici donc l’histoire d’une mini macro qu’on nommera CNT_WRD qui crée une macro variable TOT_WRD renvoyant le nombre de mots contenu dans le paramètre TXT.
Ceci est pour vous l’occasion de voir ou revoir un raisonnement possible dans la construction d’une macro sous SAS.
1. Préciser ses besoins, une rapide « spécification »
La macro CNT_WRD composée d’un seul paramètre retournera dans une macro variable TOT_WRD le nombre de mots contenus dans le texte donné dans le paramètre de macro.
Ici on considérera comme mot, tout terme séparé par au moins un blanc.
Si le paramètre de macro est vide, la macro ne devra pas afficher de message d’erreur et la macro variable TOT_WRD sera égale à 1. Par défaut, aucune valeur ne sera entrée dans le paramètre TXT.
La macro variable doit pouvoir être utilisable à l’extérieur de la macro (macro variable globale).
2. Tester la fonction COUNT dans une étape data
La fonction COUNT permet de comptabiliser certains caractères et donc de répondre à ce type de besoin. En fait, cette fonction ne compte pas le nombre de mots mais compte le nombre de caractères définis par le second élément dans la fonction; dans notre cas, elle comptera le nombre de blancs. Il faut donc ajouter 1 au total.
Voici un exemple dans une étape data.
data _null_;
tot_wrd=1+count(‘mot1 mot2’,‘ ‘);
put tot_wrd=;
run;
Dans la log, vous pouvez voir que cnt_wrd=2.
Mais cela ne suffit pas pour gérer les blancs multiples et les blancs aux extrémités. Car si vous avez plus d’un blanc entre chaque mot, chacun sera compté. Il faut donc les enlever au préalable (avec la fonction COMPBL ici). Les blancs de début et fin peuvent s’enlever au moyen de la fonction STRIP.
data _null_;
tot_wrd=1+count(strip(compbl(‘ mot1 mot2 ‘)),‘ ‘);
put tot_wrd=;
run;
Mais que ce passe t-il si notre texte à compter est vide ? TOT_WRD sera égal à 1. Il faut donc ajouter le 1 au total que si le texte à analyser n’est pas vide.
data _null_;
length txt $200;
txt=;
if txt ne ‘ ‘ then tot_wrd=1+count(strip(compbl(txt)),‘ ‘);
put tot_wrd=;
run;
3. Créer la macro
Comme indiqué dans le dernier point, on travaille ici de manière conditionnelle. Si le paramètre de macro TXT est vide, la macro variable CNT_WRD nouvellement créée prend la valeur zéro. Sinon, On passe par la fonction COUNT.
Comme il n’existe pas d’équivalent aux fonctions COUNT et COMPBL en langage macro, il faut encadrer chacune d’elle dans une fonction macro SYSFUNC.
Ici on notera que la fonction STRIP n’apparaît pas. Les blancs de début et de fin en langage macro n’ont aucun impact.
%macro cnt_wrd(txt=);
%global tot_word;
%if &txt.= %then %let tot_wrd=0;
%else %let tot_wrd=%eval(1+%sysfunc(count(%sysfunc(compbl(&txt.)),%str( ))));
%mend cnt_wrd;
Pour représenter un blanc dans une étape data, il suffit d’utiliser des guillemets. En langage macro, on fait appel à la fonction %STR(). Il faudra ne pas oublier d’ajouter un blanc entre les parenthèses.
Afin d’ajouter 1 au résultat de la fonction COUNT, il faut utiliser la macro fonction %EVAL. Le contenu des macro variables sont sinon tous interprétés comme du texte, qu’il s’agisse de nombres ou pas.
Enfin, pour que cette macro variable TOT_WRD soit utilisable en dehors de la macro, il faut qu’elle soit globale. Hors par défaut, une macro variable créée dans une macro est locale, c’est-à-dire n’existe que le temps de la macro. L’instruction %GLOBAL TOT_WRD; résouds le problème.
4. Tester la macro dans le cadre de sa validation
Que se passe t-il quand on ne change pas la valeur par défaut du paramètre de macro ?
%cnt_wrd;
%put Valeur de TOT_WRD: &tot_wrd;
Que se passe t-il quand le paramètre de macro TXT est vide de texte ?
%put Valeur de TOT_WRD: &tot_wrd;
%cnt_wrd(txt=);
%put Valeur de TOT_WRD: &tot_wrd;
Que se passe t-il lorsqu’il n’y a qu’un mot?
%cnt_wrd(txt=mot1);
%put Valeur de TOT_WRD: &tot_wrd;
Que se passe t-il quand il y a plusieurs mots ?
%cnt_wrd(txt=mot1 mot2 mot3);
%put Valeur de TOT_WRD: &tot_wrd;
Que se passe t-il quand il y a des blancs multiples entre les mots, en début et à la fin ?
%cnt_wrd(txt= mot1 mot2 mot3 );
%put Valeur de TOT_WRD: &tot_wrd;
Que se passe t-il quand il y a des blancs multiples entre les mots, en début et à la fin ?
%cnt_wrd(txt=mot1 mot2);
%put Valeur de TOT_WRD: &tot_wrd;
Que se passe t-il quand la macro est appelée plusieurs fois ?
%cnt_wrd(txt=mot1 mot2);
%put Valeur de TOT_WRD: &tot_wrd;
%cnt_wrd(txt=mot1);
%put Valeur de TOT_WRD: &tot_wrd;
Lecture complémentaire