BookmarkSubscribeRSS Feed
🔒 This topic is solved and locked. Need further help from the community? Please sign in and ask a new question.
bon0
Calcite | Level 5

Hello,

 

Can you please advise how to assign different colors for datalabels in sgplot hbar chart? With

datalabelattrs =(color=)  statement I can put just 1 color for all datalabels together, I need different color for each series (4 bars - "1","2","3" and "4" - I need to assign different color for each bar).  THANK YOU!!!

 

proc sgplot data=Americas noborder noopaque nowall pad=0 noautolegend;

goption xpixels=400 ypixels=300;

 

hbar ID / response=TotalCases stat=sum datalabel group=ID dataskin=matte

nooutline nostatlabel datalabelattrs=(size=12) clusterwidth=0.9 barwidth=0.96;

styleattrs datacolors=('#D4002C' '#009354' '#EF820F' '#6C206B');

 

 xaxis display=none valueattrs=(color=black size=11pt)

LABELATTRS=(color=black size=12pt);

yaxis values=( "1" "2" "3" "4") display=(NOVALUES NOLINE) display=none display=(noticks) label=' ' ;

run;

 

1 ACCEPTED SOLUTION

Accepted Solutions
DanH_sas
SAS Super FREQ

How about this approach?

 

datalabel.png

proc summary data=sashelp.class nway;
class age;
var weight;
output out=class mean=;
run;

proc sgplot data=class;
styleattrs datacolors=(red green blue orange purple cyan) datacontrastcolors=(red green blue orange purple cyan);
vbarparm category=age response=weight / group=age;
xaxistable weight / colorgroup=age location=inside nolabel;
run;

View solution in original post

7 REPLIES 7
Reeza
Super User
Are those hex codes? You need to put a CX before the hex code. Cx000000.

You can use data attribute maps to set colour and style. http://documentation.sas.com/?docsetId=grstatproc&docsetTarget=n18szqcwir8q2nn10od9hhdh2ksj.htm&docs...
bon0
Calcite | Level 5

Hello,

bar colors are working fine. Can you advise please how to set different colors for data labels (response values)?

E.g. - First bar is called "1" and it is red - value is 155 and should be red also. Second bar is called "2" and it is green - value is 255 and should be green ...

Jay54
Meteorite | Level 14

Bar labels use the default text color, and are not colored by group.  Since the label is right above the bar, it is not clear the benefit of coloring it.

 

If you do need it colored, you can overlay a TEXT plot with the value and group and place it at the top of your bar.  If the bars are not summarized, this will be easy.  If they are summarized, then you will need to run PROC MEANS to get the computed values.

bon0
Calcite | Level 5

Thank you for your answer but unfortunately this will not solve my problem.

 

Reason why I need it colored is because the bar values can vary significantly - e.g. 10 for the first bar and 100k for the second bar. In this case the first one will not be visible because of the measuring scale. Because I am not displaying the axis values (there are about 10 charts in the ppt slide and only 1 legend is displayed for all of them)  then it is not obvious what the first bar represents. To use hardcoded position of values will not be good because the bars can reach different values. Also absolute positioning is not possible for ods powerpoint output (as far as I know).

 

To sum up, is there an answer that this is just simply not possible with SAS?

 

 

DanH_sas
SAS Super FREQ

How about this approach?

 

datalabel.png

proc summary data=sashelp.class nway;
class age;
var weight;
output out=class mean=;
run;

proc sgplot data=class;
styleattrs datacolors=(red green blue orange purple cyan) datacontrastcolors=(red green blue orange purple cyan);
vbarparm category=age response=weight / group=age;
xaxistable weight / colorgroup=age location=inside nolabel;
run;
bon0
Calcite | Level 5

Thank you very much, this solution is sufficient for my needs.

 

Is there any way how to set a transparent background for the axistable?

 

DanH_sas
SAS Super FREQ

Sanjay made a great suggestion to use a TEXT plot for this case, since we are pre-computing the data. See if this works for you:

 

 

datalabel.png

 

 

proc summary data=sashelp.class nway;
class age;
var weight;
output out=class mean=;
run;

proc sgplot data=class;
styleattrs datacolors=(red green blue orange purple cyan) datacontrastcolors=(red green blue orange purple cyan);
vbarparm category=age response=weight / group=age;
text x=age y=weight text=weight / group=age position=top;
run;

hackathon24-white-horiz.png

The 2025 SAS Hackathon has begun!

It's finally time to hack! Remember to visit the SAS Hacker's Hub regularly for news and updates.

Latest Updates

How to Concatenate Values

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.

SAS Training: Just a Click Away

 Ready to level-up your skills? Choose your own adventure.

Browse our catalog!

Discussion stats
  • 7 replies
  • 11113 views
  • 4 likes
  • 4 in conversation