A SAS package is an automatically generated, single, stand alone zip file containing organised and ordered code structures, created by the developer and extended with additional automatically generated "driving" files (i.e. description, metadata, load, unload, and help files).
The purpose of a package is to be a simple, and easy to access, code sharing medium, which will allow: on the one hand, to separate the code complex dependencies created by the developer from the user experience with the final product and, on the other hand, reduce developer's and user's unnecessary frustration related to a remote deployment process.
In this repository we are presenting the SAS Packages Framework which allows to develop and use SAS packages.
Don't forget to STAR (:star:) the repository! :-)
The latest version of SPF is 20241207
.
To get started with SAS Packages try this Getting Started with SAS Packages
presentation (see the ./SPF/Documentation
directory).
The documentation and more advance reading would be the SAS(r) packages - the way to share (a how to)- Paper 4725-2020 - extended.pdf
article (see the ./SPF/Documentation
directory).
Short description of the SAS Packages Framework macros can be found here
Videos presenting the SPF and packages, from various conferences and meetups (the newer the better):
- "SAS Packages: The Way to Share" - SAS Global Forum 2020 V.E. (April 2020, ~20 minutes, general overview but with a bit obsolete technical details)
- "SAS Packages: The Way to Share" - SaSensei International Dojo No. 1 (April 2020, ~28 minutes, general overview but with a bit obsolete technical details)
- "Co nowego z pakietami SAS?" - SAS dla Administratorów i Praktyków 2020 (October 2020, in Polish, ~41 minutes, general overview and technical details how to use SPF)
- "SAS Packages - The Way to Share" - Boston Area SAS Users Group webinar (November 2020, ~59 minutes, general overview and technical details how to use SPF)
- "My First SAS Package: A How-To" - SAS Global Forum 2021 V.E. (May 20th 2021, ~30 minutes, technical workshop on how to create a package)
- "Kod SASowy ukryty na widoku" - SAS dla Administratorów i Praktyków 2021 (November 24th 2021, in Polish, ~34 minutes, technical presentation with details about the GSM package)
- "A BasePlus Package for SAS" - SAS Explore 2022 (September 27th-29th 2022, ~28 minutes, technical presentation with details about the BasePlus package), alternative video at YouTube is here
- "SAS Packages - State of the Union" - SaSensei International Dojo No. 13 (November 10th 2022, ~50 minutes, general overview with the latest technical details)
- "SAS Packages Framework - an easy code sharing medium for SAS" - Warsaw IT Days 2023 (March 31st 2023, ~60 minutes, general overview with technical details for user and developer)
Here are links to some tutorials which may help you to start with the framework. Order is dictated by the amount of details presented. Letter "D" indicates tutorial dedicated for developers and "U" materials for users.
-
(DU) The latest video explaining the idea.
-
(D) Very simple "Hello World" example tutorial for developers. As a support a walk-through video
-
(D) Article and all required materials for "My first SAS Package" tutorial.
-
(DU) Materials from Hands-on-Workshop (4+ hours) tutorial: Share your code with SAS Packages. It is a "zero to hero" tutorial that explains all the "bells and whistles" of using, and all the "nuts and bolts" of developing SAS packages.
A SASware Ballot Idea for adding SAS Packages Framework macros into Base SAS and Viya was submitted Friday, May 27th 2022. If you would like to support the idea visit this communities.sas.com post and up vote the idea!
The first step to use a package with the SAS Packages Framework:
- Create a folder for your packages, under Windows OS family e.g.,
C:/SAS_PACKAGES
or under Linux/UNIX OS family e.g.,/home/<username>/SAS_PACKAGES
.
Then either:
- Manually download the
SPFinit.sas
file (the SAS Packages Framework) into the local packages folder. - [Optional] Manually download the
<packageName>.zip
file into the local packages folder. - and Execute:
filename packages "<directory/containing/packages/>"; /* setup directory for packages */
%include packages(SPFinit.sas); /* enable the framework */
/* %installPackage(packageName) */ /* install the package, unless you downloaded it manually */
%helpPackage(packageName) /* get help about the package */
%loadPackage(packageName) /* load the package content into the SAS session */
or if you need it just for "one time" only:
- Execute:
filename packages "%sysfunc(pathname(work))"; /* setup WORK as temporary directory for packages */
filename SPFinit url "https://raw.githubusercontent.com/yabwon/SAS_PACKAGES/main/SPF/SPFinit.sas";
%include SPFinit; /* enable the framework */
%installPackage(packageName) /* install a package */
%helpPackage(packageName) /* get help about the package */
%loadPackage(packageName) /* load the package content into the SAS session */
or do it pragmatically:
- Enable the framework [first time only]:
filename SPFinit url "https://raw.githubusercontent.com/yabwon/SAS_PACKAGES/main/SPF/SPFinit.sas";
%include SPFinit; /* enable the framework */
or (shorter) with:
filename SPFinit url "https://bit.ly/SPFinit";
%include SPFinit; /* enable the framework */
- Install the framework on your machine in the folder you created:
filename packages "<directory/containing/packages/>";
%installPackage(SPFinit) /* install the framework */
- From now on run it like this:
filename packages "<directory/containing/packages/>";
%include packages(SPFinit.sas);
%installPackage(packageName) /* install a package */
%helpPackage(packageName) /* get help about the package */
%loadPackage(packageName) /* load the package content into the SAS session */
The "Workshop video for the User" got outdated (in general). Newer version is coming soon, in the mean time see some of the videos from the "Recordings and Presentations" section above.
(You can watch the workshop if you wish, link is working and some parts are still valid source of information e.g., "ICE
loading" or "disk
loading")
Workshop video for the User [May 6th, 2020] [~86 minutes, outdated (installPackage macro was not there yet) but gives the idea how it works especially load, help, unload, ICEload, and other details]
To create your own package:
-
Download (and use) the
SPFinit.sas
file (the SAS Packages Framework), the part of the framework required for testing is there too. -
See this "Hello World" example tutorial.
-
Read the
SAS Packages - The Way to Share (a How-To) - Paper 4725-2020 - extended version
article to learn more details. -
Read the
My First SAS Package: A How-To - Paper 1079-2021
article available at communities.sas.comhere
or locallyhere
The SAS Packages Framework (short) documentation to quickly see macros options and parameters.
Update[October 27th, 2024]: %splitCodeForPackage()
utility macro is available. (see here).
Update[October 14th, 2024]: DS2PCK
and DS2THR
types for PROC DS2
threads and packages added to the framework. (see here).
Update[December 10th, 2023]: markdownDoc=
parameter added to %generatePackage()
macro, which allows to generate markdown file with documentation. Content is taken from the help information notes and the description. (see here).
Update[November 11th, 2023]: KMFSNIP
type for key macro abbreviations snippets added to the framework. (see here).
Update[February 7th, 2023]: ADDCNT
**type for additional content feature and ** %loadPackageAddCnt()
macro added to the framework. (see here).
Update[December 12th, 2022]: CASLUDF
type for CASL user defined functions added to the framework. Utility macros for for loading content in proc IML and proc CAS added. (see here).
Update[November 21st, 2022]: %loadPackage()
macro allows Cherry Picking of content (see here).
Update[September 30th, 2022]: New dedicated repository: SASPAC - the SAS Packages Archive is available as new location for packages storage. Location of SASPAC is: https://github.com/SASPAC
Update[November 11th, 2021]: %extendPackagesFileref()
macro is available.
Update[October 15th, 2020]: %previewPackage()
macro is available.
Update[September 11th, 2020]: %loadPackageS()
and %verifyPackage()
macros are available.
Update[July 30th, 2020]: All components of SAS Packages Framework are now in one file SPFinit.sas
(located in the ./SPF
directory). Documentation moved to ./SPF/Documentation
directory. Packages zip files moved to ./packages
directory.
Update[June 10th, 2020]: To see help info about framework macros and their parameters just run: %generatePackage()
, %installPackage()
, %helpPackage()
, %loadPackage()
, and %unloadPackage()
with empty parameter list.
Update[June 3rd, 2020]: %installPackage()
macro is available. The %installPackage()
macro is embedded in the loadpackage.sas
part of the framework.
This is a list of locations where the SAS Packages Framework is used:
- Warsaw (Poland)
If you want to share that you are using the SPF let me know and I'll update the list.
If you find the SPF useful share info about it or give it a star (:star:) so more people will know.
This section presents some examples of available SAS packages.
(!) Since September 2022 the default and official location for packages is SASPAC - the SAS Packages Archive located under: https://github.com/SASPAC
where each package is stored as a separate repository with historical versions.
(!) For "backward compatibility"/historical point of view the following packages are also available under the ./packages
directory in this repository.
Packages:
-
SQLinDS
-
DFA (Dynamic Function Arrays)
-
macroArray
-
BasePlus
-
GSM (Generate Secure Macros)
-
dynMacroArray
Development of this package is currently on hold.