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
Rhodochrosite | Level 12

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-2024.png

Join us for SAS Innovate April 16-19 at the Aria in Las Vegas. Bring the team and save big with our group pricing for a limited time only.

Pre-conference courses and tutorials are filling up fast and are always a sellout. Register today to reserve your seat.

 

Register now!

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
  • 4546 views
  • 4 likes
  • 4 in conversation