1

我有以下内容,但我希望控制数据的显示顺序。我希望根据用户指定的顺序显示条形,而不是按 A、B、C、D、E、F 的顺序显示条形。例如,我希望能够在 SAS 数据集中为一个名为的变量分配一个值,该变量rank将控制条形图的堆叠顺序。

我怎样才能做到这一点?

%let name=ex_17;
%let myfont=Albany AMT;
goptions reset=all;
goptions reset=(global goptions);
/*GOPTIONS DEVICE=png xpixels=800 ypixels=400;*/
goptions gunit=pct border cback=white colors=(blacks) ctext=black
htitle=4 htext=3.0 ftitle="&myfont" ftext="&myfont";

data mileage;
      length factor $ 24;
   input factor $ level $ value;    
   datalines;
C left -38.882
C right 39.068
D right 38.99
D left -38.97
E right 38.982
E left -38.975
F left -38.973
F right 38.979
B left -38.975
B right 38.975
A right 38.977 
A left -38.973
;

/* base case: 38.975  */
data mileage;
    set mileage;
    if level="right" then value = value - 38.975;
    if level="left" then value = -1*(38.975 - value*-1);
run;

data convert;
   set mileage;
   *if level='left' then value=-value;
run;

proc format;
   picture posval low-high='000,009';
run;

data anlabels(drop=factor level value);
   length text $ 24;
   retain function 'label' when 'a' xsys ysys '2' hsys '3' size 2;

   set convert;
   midpoint=factor; subgroup=level;

   *text=left(put(value, BEST6.3));

   if level ='left' then position='>';
   else position='<'; output;
run;

title1 'Sensitivity Analysis graph';
*footnote1 justify=left ' SAS/GRAPH' move=(+0,+.5) 'a9'x move=(+0,-.5) ' Software'
          justify=right 'DRIVER ';
*title2 'by Daniel Underwood' h=3.0;
footnote1 'Estimates accurate within +/- 0.002';

*axis1 label=(justify=left 'Disutility') style=0 color=black;
axis1 label=(justify=left '') style=0 color=black;
*axis2 label=none value=(tick=3 '') minor=none major=none
      width=3 order=(-10000 to 20000 by 10000) color=black;
axis2 label=none minor=none major=none value=(tick=3 '')
      width=3 order=(-0.093 to 0.093 by 0.186) color=black;


pattern1 value=solid color=ltgray;
pattern2 value=solid color=ltgray;
/*
goption vpos=25;
goptions vsize=5in;
*/
proc gchart data=convert;
   format value BEST6.3;
   note move=(40,90) height=3 'Women' move=(+12,+0) 'Men';
   hbar factor / sumvar=value discrete nostat subgroup=level
              maxis=axis1 raxis=axis2 nolegend annotate=anlabels
              coutline=same des='' space=2;
run;

quit;
4

1 回答 1

1

显示值的顺序由 AXIS 语句(对中点或图表变量排序)或 LEGEND 语句(对子组变量的值排序)上的 ORDER= 选项控制。

如果您正在寻求一种使用名为 RANK 的变量来控制子组变量顺序的方法,这里有一个 SAS 示例程序可以做到这一点。

于 2013-04-28T20:38:40.700 回答