Hello,
I used "proc report" to output my final summary to excel file.
However, the yellow highlighted space below is gone from the output excel.
I am wondering how I can keep it. 
Thank you. 
Also, I am wondering why the "." change to "0" in the excel output.
Thank you.
Hi:
I find that I need to use INDENT= with PROC REPORT in order to have any indenting respected. You did not show your code so my guess is that you either padded your line on the left with leading blanks (which doesn't work) or else you used the LEFTMARGIN= style override (which works for PDF and RTF). When I use INDENT= along with some helper variables to specify which lines need to be indented, Excel uses my INDENT= style override, as shown below:
Hope this helps,
Cynthia
We do not have your starting data or your code to create the report or to send the result to Excel so really cannot answer.
In SAS most places where the N statistic is used the result is a 0 when counting something if there are none.
And example that you should be able to run as the SASHELP.CLASS set should be available.
proc freq data=sashelp.class; tables sex*age /norow nocol nopercent; run;
There are no records with a Sex=F and Age=16 so the count result is 0.
Thank you very much.
The following are the codes with "." in the name column which output as 0 in the excel output.
proc report data=final split='~';
column ord name trt1 trt2 flag pvalue;
define ord / order noprint;
compute name;
if flag=0 then do;
call define(_col_,'style','style=[fontweight=bold]');
end;
else do;
call define(_col_, 'style','style=[asis=on]');
end;
endcomp;
run;
Hi:
I find that I need to use INDENT= with PROC REPORT in order to have any indenting respected. You did not show your code so my guess is that you either padded your line on the left with leading blanks (which doesn't work) or else you used the LEFTMARGIN= style override (which works for PDF and RTF). When I use INDENT= along with some helper variables to specify which lines need to be indented, Excel uses my INDENT= style override, as shown below:
Hope this helps,
Cynthia
Thank you, Cythnia.
When I used your codes, it said "Variable indent is uninitialized".
It was in the test data. I am wondering how to fix it.
28 proc report data=test split='~';
29 column ord name trt1 trt2 indent pvalue;
30 define ord / order noprint;
31 compute name;
32 if indent=0 then do;
33 call define(_col_,'style','style=[fontweight=bold]');
34 end;
35 else if indent=1 then do;
36 call define(_col_, 'style','style=[asis=on]');
37 end;
38 endcomp;
39 
40 run;
NOTE: Variable indent is uninitialized.
NOTE: There were 26 observations read from the data set WORK.TEST.
Hi:
INDENT= is a style override and in my program, I have a helper variable called INDENT that I use to determine which INDENT= value to use. In the DATA step program at the top of my screen shot. So I see that you seem to have created a helper variable called INDENT. But you have it at the end of the report row in your COLUMN statement.
Notice in my program, how my "helper" variables are all placed to the left side of the TEXT variable. This is because of the left-to-right rule of how PROC REPORT processes the items on the report row. I see you have an INDENT variable listed on your COLUMN statement, but if you want to test INDENT in order to change the style for the NAME variable, then you have to use the same left-to-right ordering that I used. Your INDENT variable will need to be placed on the COLUMN statement before the NAME variable. Since you did not provide any data to work with, it's impossible to run your program without making.
Also, your code does not use the INDENT= style option. I only see ASIS=ON. I am not sure that will be respected by Excel when it opens the file.
Cynthia
It's finally time to hack! Remember to visit the SAS Hacker's Hub regularly for news and updates.
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.
Ready to level-up your skills? Choose your own adventure.
