Hi,
I would like to get two decimal places in my output (default is three), but I can't seem to make it work. I tried both ods output and format w.d 8.2 without any success, but maybe I didn't do it properly? This is the the SAS code that I'm using:
proc phreg data=have nosummary;
model (entry,exit)*failure(0)=exposure / risklimits;
run;
I'm fairly new to SAS so I apologise in advance if I'm not using the correct terminology when posting this.
@YezzieBay wrote:
Hi,
I would like to get two decimal places in my output (default is three), but I can't seem to make it work. I tried both ods output and format w.d 8.2 without any success, but maybe I didn't do it properly? This is the the SAS code that I'm using:
proc phreg data=have nosummary;
model (entry,exit)*failure(0)=exposure / risklimits;
run;
I'm fairly new to SAS so I apologise in advance if I'm not using the correct terminology when posting this.
Please show the code you tried for ODS output that did not work. Best would be to paste code and messages from the log into a code box opened with the forum's {i} menu icon.
Other approaches would involve modifying table templates which would be more complex and for some procedures would involve modifying many templates.
I've now managed to make ods output work by using this code:
ods output ParameterEstimates=new; proc phreg data=have nosummary; model (entry,exit)*failure(0)=exposure / risklimits; run; proc print data=new noobs; format hazardratio 8.2 HRLowerCL 8.2 HRUpperCL 8.2; run;
However, this creates a new dataset with the estimates. Would it be possible to get two decimal places in the output from the proc phreg directly? Thanks!
Run this code:
proc template; path sashelp.tmplmst; list stat.phreg; run;
You would have to modify EACH of the templates that show the type of Table and some of the Link to do what you want.
For example the template code for Estimates looks like:
proc template; link Stat.PHReg.Estimates to Stat.Lmr.Estimates; define table Stat.Lmr.Estimates; notes "Results from ESTIMATE statements"; dynamic Title Title2 FirstSpace FirstQuant LastQuant FirstQuantMu LastQuantMu FirstQuantExp LastQuantExp; header H1 H2 QuantHeader QuantMuHeader QuantExpHeader; define H1; text Title; split = ";"; space = FirstSpace; end; define H2; text Title2; space = 1; end; define QuantHeader; text "Percentiles"; expand = "-"; end = LastQuant; start = FirstQuant; spill_margin; generic; end; define QuantMuHeader; text "Percentiles for Mean"; expand = "-"; end = LastQuantMu; start = FirstQuantMu; spill_margin; generic; end; define QuantExpHeader; text ";Percentiles for;Exponentiated"; expand = "-"; end = LastQuantExp; start = FirstQuantExp; spill_margin; generic; end; parent = Stat.LMR.tTests; end; run;
Which from the statement parent = Stat.LMR.tTests means you need to look in that template to find the names of more variables that Estimates might contain and then add define statements to set all of the formats as desired.
Plus you have to take care not to accidentally replace the SAS supplied templates with your custom template and then tell SAS when to use your custom template in stead of the SAS supplied.
Good luck. That would be way beyond the scope of what I have time to help with here.
I will try this. Thank you for your help!
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 16. Read more here about why you should contribute and what is in it for you!
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.