BookmarkSubscribeRSS Feed
🔒 This topic is solved and locked. Need further help from the community? Please sign in and ask a new question.
DmytroYermak
Lapis Lazuli | Level 10

Hi all,

 

Could you please help to correct the code:

 

proc sgplot data=F1 noautolegend;

   styleattrs datacontrastcolors=(black)
               datasymbols=(trianglefilled circlefilled squarefilled diamondfilled triangle circle square diamond)
               datalinepatterns=(solid); 

   scatter x=PCTPT y=mean 
							grouporder=data
                            yerrorlower=lower                                                                                            
                            yerrorupper=upper
                            name = "Scatter" ;                                                                               
   series x=PCTPT y=mean /   name = "Series";

   xaxis type = discrete;
   yaxis type = log;

 
run;  

 

 

 

1 ACCEPTED SOLUTION

Accepted Solutions
Jay54
Meteorite | Level 14

Both above suggestions will work.  If you just need different attributes per group, and not specific attribute per group "value" (as in IBM should always be blue), an easier way is to use the SGPLOT STYLEATTRS statement.  No need to create a new style or a Discrete Attributes data set.  Please see blog article on this topic.

View solution in original post

5 REPLIES 5
WarrenKuhfeld
Ammonite | Level 13

If you are asking how to make SGPLOT use your new style, then put it on a destination statement.  Example:

ods html style=newblue;

ballardw
Super User

Another approach could be the option DATTRMAP which allows you to specify group symbol appearance options based on the values of your group variable without changing any style.

 

DATTRMAP is a data set that would be referenced on the Proc statement and then an attrid option is added to the specific plots to indicate which attribute map value to use with that specific plot.

Your data set would have one line for each value of the group variable, a name to reference and values for the graph items you want to use.

Jay54
Meteorite | Level 14

Both above suggestions will work.  If you just need different attributes per group, and not specific attribute per group "value" (as in IBM should always be blue), an easier way is to use the SGPLOT STYLEATTRS statement.  No need to create a new style or a Discrete Attributes data set.  Please see blog article on this topic.

DmytroYermak
Lapis Lazuli | Level 10

Thank you! It has sorted everything out in one minute.

DmytroYermak
Lapis Lazuli | Level 10

Final code (if someone is interested):

proc sgplot data=F1 noautolegend;

   styleattrs datacontrastcolors=(black)
               datasymbols=(trianglefilled circlefilled squarefilled diamondfilled triangle circle square diamond)
               datalinepatterns=(solid); 

   scatter x=PCTPT y=mean / group=TRT01A
							grouporder=data
                            yerrorlower=lower                                                                                            
                            yerrorupper=upper
                            name = "Scatter" ;                                                                               
   series x=PCTPT y=mean /  markers group=TRT01A name = "Series";

   xaxis type = discrete;
   yaxis type = log;

   keylegend "Series"  / location=outside position=topright across=1 noborder;
   format PCTPT $PCTPTF.;
 
run;  

SAS Innovate 2025: Call for Content

Are you ready for the spotlight? We're accepting content ideas for SAS Innovate 2025 to be held May 6-9 in Orlando, FL. The call is open until September 25. Read more here about why you should contribute and what is in it for you!

Submit your idea!

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.

Click image to register for webinarClick image to register for webinar

Classroom Training Available!

Select SAS Training centers are offering in-person courses. View upcoming courses for:

View all other training opportunities.

Discussion stats
  • 5 replies
  • 12109 views
  • 4 likes
  • 4 in conversation