I drawing some graphs (time series) with PROC SGPLOT. I use the GROUP function to have one line for each group. The value of the group in my dataset is numerical (i.e. 0,1,2,3,4,5). However, when I draw the graphs, I would like to assign some name to each group so that it displays the names instead of the numbers.
proc sgplot data=population;
styleattrs datacontrastcolors=(red blue orange black)
datasymbols=(circlefilled trianglefilled squarefilled dot)
datalinepatterns=(solid dash longdash dot) ;
series x=year y=population/group=continent;
run;
*continent variable can be 1,2,3,4 which corresponds to Asia, Europe, America and Africa;
*So instead of displaying 4 lines with label 1,2,3,4 on the bottom, I would like to display Asia, Europe, America, Africa;
Well, one way is to create another variable and assign string values corresponding to the numerical value. But I dont really want to do this as it consumes memory. I hope there is a quick way with PROC SGPLOT
Create a format with your decodes/strings, and apply the format to the data:
proc format; value tmp 1="Asia" 2=...; run; data population; set population; format continent tmp.; run;
Then it should display the strings.
Create a format with your decodes/strings, and apply the format to the data:
proc format; value tmp 1="Asia" 2=...; run; data population; set population; format continent tmp.; run;
Then it should display the strings.
Formatting does not change the underlying data, its still the number if you remove the format. If you don't want to format the a data and you do not want to create a new variable, then you are stuck I am afraid, you have to tell SAS somehow what values to display.
Registration is open! SAS is returning to Vegas for an AI and analytics experience like no other! Whether you're an executive, manager, end user or SAS partner, SAS Innovate is designed for everyone on your team. Register for just $495 by 12/31/2023.
If you are interested in speaking, there is still time to submit a session idea. More details are posted on the website.
Learn how use the CAT functions in SAS to join values from multiple variables into a single value.
Find more tutorials on the SAS Users YouTube channel.