Hi, we are trying to use sgplot varbar ,
option: vbar x / response =y stat=mean datalabel ;
to put mean data above each bar. however, we found we have no way to format datalabel.
Is there a way to format datalabel to avoid long tail of the mean?
We tried to format response Y. But it seems sgplot gave a mean based on formatted Y, lacking original precision.
ie. after formating Y, MEAN=2.12, but using the real numbers Mean=2.13, how we solve this?
hard to pass QC.
ANY IDEA HOW TO SOLVE THIS?
Thank you!
What version of SAS are you using?
I am using SAS9.2 ON WIN7
Are you getting the 2.13 if you use PROC MEANS?
Thank you all,
Our QC people found the issue. they compare the values from tabulate against the graph from SGPLOT.
we used picture format .
If use means, i figure it will be same thing. may be i can get it done using GTL, but need to start afresh from syntax.
Is there easy ways to get it done.
PROC FORMAT;
PICTURE TAB (ROUND)
1000000 - <10000000= "09999999"
100000 - <1000000 = "0999999"
10000 - <100000 = "099999"
1000 - <10000 = "09999"
100 - <1000 = "0999"
10 - <100 = "099.9"
1 - <10 = "09.99"
.1 - <1 = "9.999"
.01 - <0.1 = "9.9999"
.001 - <0.01 = "9.99999"
.0001 - <0.001 = "9.999999"
.00001 - <0.0001 = "9.9999999"
.000001 - <0.00001 = "9.99999999"
.0000001 - <0.000001= "9.999999999"
-10000000 - <-1000000= "09999999" (PREFIX="-")
-1000000 - <-100000 = "0999999" (PREFIX="-")
-100000 - <-10000 = "099999" (PREFIX="-")
-10000 - <-1000 = "09999" (PREFIX="-")
-1000 - <-100 = "0999" (PREFIX="-")
-100 - <-10 = "099.9" (PREFIX="-")
-10 - <-1 = "09.99" (PREFIX="-")
-1 - <-0.1 = "9.999"(PREFIX="-")
-.1 - <-0.01 = "9.9999"(PREFIX="-")
-.01 - <-0.001 = "9.99999"(PREFIX="-")
-.001 - <-0.0001 = "9.999999"(PREFIX="-")
-.0001 - <-0.00001 = "9.9999999"(PREFIX="-")
-.00001 - <-0.000001 = "9.99999999"(PREFIX="-")
-.000001 - <-0.0000001= "9.999999999"(PREFIX="-")
;
proc template;
define statgraph mean;
begingraph;
entrytitle 'Mean Mileage by Type';
layout overlay;
barchart x=type y=mpg_city / stat=mean
barlabel=true barlabelformat=4.1;
endlayout;
endgraph;
end;
run;
ods listing;
ods graphics / reset width=5in height=3in imagename='mean';
proc sgrender data=sashelp.cars template=mean;
run;
I would suggest to store the rounded values in a variable and add this variable after datalabel=.
proc format;
picture twodigits (round) low-high='009.99';
run;
proc sql;
create table class as
select sex, height, put(mean(height),twodigits.) as mean_height
from sashelp.class
group by sex;
quit;
*before;
proc sgplot data=class;
vbar sex / response =height stat=mean datalabel;
run;
*after;
proc sgplot data=class;
vbar sex / response =height stat=mean datalabel=mean_height;
run;
Join us for SAS Innovate 2025, our biggest and most exciting global event of the year, in Orlando, FL, from May 6-9. Sign up by March 14 for just $795.
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.
Ready to level-up your skills? Choose your own adventure.