Le script ne lit aucune donnée source. Sa finalité est de créer une fonction réutilisable qui, elle-même, écrit des données textuelles fournies en paramètre dans un fichier sur le système de fichiers. L'origine des données traitées par la fonction est donc externe à ce script mais interne à son propre appel.
1 Bloc de code
PROC FCMP
Explication : Ce bloc est exécuté si `wrap=YES`. Il utilise `PROC FCMP` pour définir et compiler une nouvelle fonction `mcf_string2file`. La fonction utilise les fonctions de fichiers SAS (`filename`, `fopen`, `fput`, `fwrite`, `fclose`) pour écrire une chaîne de caractères dans un fichier. Elle retourne 0 en cas de succès et -1 en cas d'erreur (ex: impossible d'ouvrir le fichier).
Copié !
proc fcmp outlib=&lib..&cat..&pkg;
function mcf_string2file(filepath $, string $, mode $);
if mode='APPEND' then fmode='a';
else fmode='o';
length fref $8;
rc=filename(fref,filepath);
if (rc ne 0) then return( -1 );
fid = fopen(fref,fmode);
if (fid = 0) then return( -1 );
rc=fput(fid, string);
rc=fwrite(fid);
rc=fclose(fid);
rc=filename(fref);
return(0);
endsub;
quit;
1
PROC FCMP outlib=&lib..&cat..&pkg;
2
3
function mcf_string2file(filepath $, string $, mode $);
4
IF mode='APPEND'THEN fmode='a';
5
ELSE fmode='o';
6
LENGTH fref $8;
7
rc=filename(fref,filepath);
8
IF (rc ne 0) THEN return( -1 );
9
fid = fopen(fref,fmode);
10
IF (fid = 0) THEN return( -1 );
11
rc=fput(fid, string);
12
rc=fwrite(fid);
13
rc=fclose(fid);
14
rc=filename(fref);
15
return(0);
16
endsub;
17
18
19
QUIT;
2 Bloc de code
OPTIONS
Explication : Ce bloc de code macro vérifie si la bibliothèque de fonctions (`&lib..&cat`) est déjà présente dans l'option système `CMPLIB`. S'il ne la trouve pas, il l'ajoute dynamiquement via `options insert=(CMPLIB=...)`. Cela garantit que la fonction FCMP qui vient d'être créée est immédiatement accessible dans la session SAS.
Copié !
/* insert the CMPLIB if not already there */
%let cmpval=%sysfunc(getoption(cmplib));
%let found=0;
%do i=1 %to %sysfunc(countw(&cmpval,%str( %(%))));
%let var=%scan(&cmpval,&i,%str( %(%)));
%if &var=&lib..&cat %then %let found=1;
%end;
%if &found=0 %then %do;
options insert=(CMPLIB=(&lib..&cat));
%end;
Ce matériel est fourni "tel quel" par We Are Cas. Il n'y a aucune garantie, expresse ou implicite, quant à la qualité marchande ou à l'adéquation à un usage particulier concernant le matériel ou le code contenu dans les présentes. We Are Cas n'est pas responsable des erreurs dans ce matériel tel qu'il existe maintenant ou existera, et We Are Cas ne fournit pas de support technique pour celui-ci.
SAS et tous les autres noms de produits ou de services de SAS Institute Inc. sont des marques déposées ou des marques de commerce de SAS Institute Inc. aux États-Unis et dans d'autres pays. ® indique un enregistrement aux États-Unis. WeAreCAS est un site communautaire indépendant et n'est pas affilié à SAS Institute Inc.
Ce site utilise des cookies techniques et analytiques pour améliorer votre expérience.
En savoir plus.