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

hi, the below code prints the results even thought i have places ods close statement.

 

I mean it print in HTML which i don't want 

 

Could you please anyone advise how to stop printing ?

 

/*R_squared*/
ods html close;
proc logistic data=data1.;
ods Output rsquare=r2.;
model bad=good/rsquare;
run;
ods html close;
1 ACCEPTED SOLUTION

Accepted Solutions
FreelanceReinh
Jade | Level 19

Hi @Toni2,

 

You can use the ODS SELECT statement (or similarly the ODS EXCLUDE statement) to restrict the output to the dataset requested in the ODS OUTPUT statement.

ods select none;
proc logistic ...
...
ods output ...;
...
run;
ods select all;

The ODS OUTPUT statement can also precede the PROC LOGISTIC statement, but must be inside the pair of ODS SELECT statements.

 

(The period after "r2" is incorrect, btw.)

 

 

View solution in original post

5 REPLIES 5
ballardw
Super User

Which ODS destination is open? To use ODS OUTPUT you must have at least one ODS Destination open or no output will be created.

Or for some procedures you may be able to get what you want with an output statement but that may not have all the bits that you want.

Toni2
Lapis Lazuli | Level 10
i am not sure which destination is open. My issue here is i want to run the code in loop and it is going to take ages to print results. i need them only in the output table. Is there any workaround?
FreelanceReinh
Jade | Level 19

@Toni2 wrote:
My issue here is i want to run the code in loop and it is going to take ages to print results.

If performance is an issue, you may even want to go a step further and also use ODS NORESULTS (and ODS GRAPHICS OFF if your procedure creates unwanted graphs): see Rick Wicklin's macros ODSOff and ODSOn in his blog article Turn off ODS when running simulations in SAS.

Reeza
Super User

@Toni2 wrote:
i am not sure which destination is open. My issue here is i want to run the code in loop and it is going to take ages to print results. i need them only in the output table. Is there any workaround?

You need to use the ODS SELECT option demo'd by @FreelanceReinh 

 

And in case you missed it,  you'll need to pick a unique name for your output data set otherwise it will get overwritten each run. 

FreelanceReinh
Jade | Level 19

Hi @Toni2,

 

You can use the ODS SELECT statement (or similarly the ODS EXCLUDE statement) to restrict the output to the dataset requested in the ODS OUTPUT statement.

ods select none;
proc logistic ...
...
ods output ...;
...
run;
ods select all;

The ODS OUTPUT statement can also precede the PROC LOGISTIC statement, but must be inside the pair of ODS SELECT statements.

 

(The period after "r2" is incorrect, btw.)

 

 

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
  • 5 replies
  • 4164 views
  • 4 likes
  • 4 in conversation