Sas 计算百分比和分数

Sas 计算百分比和分数,sas,data-manipulation,Sas,Data Manipulation,假设我有如下数据: ID A1Q A2Q B1Q B2Q Continued 23 1 2 2 3 24 1 2 3 3 为了理解它翻译成的表格,ID为23的人对问题A1、A2、B1、B2分别给出了答案1、2、2、4。我想知道如何知道在整个数据集中回答1、2或3的学生的百分比 我试过使用 PROC FREQ data = test.one; tables A2Q-A2Q; tables B1Q-B2Q; RUN; 但这并不能满足我的需求。它分别分析每个问题,输

假设我有如下数据:

ID   A1Q A2Q B1Q B2Q Continued
23      1  2 2 3 
24      1  2 3 3 
为了理解它翻译成的表格,ID为23的人对问题A1、A2、B1、B2分别给出了答案1、2、2、4。我想知道如何知道在整个数据集中回答1、2或3的学生的百分比

我试过使用

PROC FREQ data = test.one;
tables A2Q-A2Q;
tables B1Q-B2Q;
RUN;
但这并不能满足我的需求。它分别分析每个问题,输出很长。我只需要把它放在一个表中,告诉我这个百分比回答了1,这个百分比回答了2,等等

输出可以是:

Question:         1    2   3
Percentage A1Q    40%  40%  20%
Percentage A2Q    60%  20%  20%
Total Percentage  30%  30%  40%

所以它可以翻译成40%的人选择1,40%的人选择2,30%的人选择3作为问题A1Q。总的百分比是在所有给出答案的人中,30%的人选择了1,30%的人选择了2,40%的人选择了3。

我的建议是转换数据,然后进行proc freq或proc tablate。我建议您将proc表格化,这样您就可以格式化您的输出,因为看起来您有分组的问题

 data long;
    set have;

    array qs(*) a1q--b2q; *list first and last variable and everything in between will be included;

    do i=1 to dim(qs);
       question=vname(qs(i));
       response=qs(i);
       output;
     end;

     keep id question response;
 run;

 proc freq data=long;
     table question*response/list;
 run;

你仍然需要做一点工作,并转换最终结果,但这可能是一个开始。。。另外,如果你有很多问题,考虑把它打包在一个宏程序中。< /P>
data quest;
input ID  A1Q A2Q B1Q B2Q;
datalines;
21 2 3 1 2
22 3 2 2 3
23 1 2 2 3 
24 1 2 3 3
25 2 1 3 3
run;

options missing = 0;    

proc freq data=quest;
  table A1Q / nocol nocum nofreq out = freq1(rename=(A1Q=Answer Count=A1Q));
  table A2Q / nocol nocum nofreq out = freq2;
  table B1Q / nocol nocum nofreq out = freq3;
  table B2Q / nocol nocum nofreq out = freq4;
run;

proc sql;
  create table results as
    select freq1.Answer,
           freq1.Percent as pctA1Q,
           freq2.Percent as pctA2Q,
           freq3.Percent as pctB1Q,
           freq4.Percent as pctB2Q
      from freq1
        left join freq2 
          on freq1.Answer = freq2.A2Q
        left join freq3
          on freq1.Answer = freq3.B1Q
        left join freq4
          on freq1.Answer = freq4.B2Q;
quit;

您能再添加几行并演示您希望输出的内容吗?当然,我会编辑原始帖子。完成,谢谢您的关注!我不是Proc tablate的忠实粉丝,但正如@Reeza所建议的那样,探索这条途径可能是值得的