Bellow is what I used to create a new variable but I am getting an error when I run my ttest:
data mergeddata;
set mergedfinal-fmt;
var1 = 'promis_pa_scale1';
var2 = 'promis_pa_scale3';
var3 = 'promis_pa_scale4';
var4 = 'promis_pa_scale5';
length pascale $ 69;
pascale = catx(',', var1, var2, var3, var4);
put _all_;
run;
data mergeddata;
set mergedfinal_fmt;
var1 = 'promis_pa_scale1_fu';
var2 = 'promis_pa_scale3_fu';
var3 = 'promis_pa_scale4_fu';
var4 = 'promis_pa_scale5_fu';
length pascale_fu $ 79;
pascale_fu = catx(',', var1, var2, var3, var4);
put _all_;
run;
proc ttest data= mergeddata;
paired pascale*pascale_fu;
run;
I figured out my mistake, here's what i did.
data finalaverage;
set mergedfinal;
intervention= (promis_pa_scale1 + promis_pa_scale3 + promis_pa_scale4 + promis_pa_scale5)/4;
comparison= (promis_pa_scale1_fu + promis_pa_scale3_fu + promis_pa_scale4_fu + promis_pa_scale5_fu)/4;
run;
data promispa;
set finalaverage;
diff= (intervention/comparison)+ 1;
run;
proc ttest data= promispa;
paired intervention*comparison;
run;
You need to show the log for the step with the error.
You cannot run a TTEST on a character variable.
I figured out my mistake, here's what i did.
data finalaverage;
set mergedfinal;
intervention= (promis_pa_scale1 + promis_pa_scale3 + promis_pa_scale4 + promis_pa_scale5)/4;
comparison= (promis_pa_scale1_fu + promis_pa_scale3_fu + promis_pa_scale4_fu + promis_pa_scale5_fu)/4;
run;
data promispa;
set finalaverage;
diff= (intervention/comparison)+ 1;
run;
proc ttest data= promispa;
paired intervention*comparison;
run;
@Rou wrote:
I figured out my mistake, here's what i did.
Great. Mark your own response as the solution, so that other will see this listed as a solved topic.
Available on demand!
Missed SAS Innovate Las Vegas? Watch all the action for free! View the keynotes, general sessions and 22 breakouts on demand.
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.