SPSS中的条件过滤

时间:2015-06-16 14:59:52

标签: spss

我使用SPSS宏为不同的选区创建了许多报告。其中一组只想要女性受访者的数据,但其他人希望数据中有男性和女性受访者。是否可以在SPSS中创建条件过滤器,以便我可以对所有报告使用相同的循环,或者我是否必须为只想要女性的组创建单独的语法?

编辑:我的代码的删节版本如下所示:

DEFINE !ess1 (inum=!charend ('/') 
/ iname=!charend ('/')
/ iname2=!charend ('/')
/ g1=!charend ('/')
/ g2=!charend ('/')
/ g3=!charend ('/')
/ g4=!charend ('/')).

RECODE INST 
    (!inum=1) 
    ( !g1 = 2) 
    (!g2= 3)    
    (!g3=4)
    (!g4=5)
    into cgroup.
MISSING VALUES cgroup(-9).
variable labels cgroup 'Comparison Group'.
value labels cgroup 1 !iname2 2 'Thing1' 3 'Thing2' 4 'Thing3' 5 'Thing4'.
EXECUTE.

USE ALL.
VARIABLE LEVEL ALL (NOMINAL).

CTABLES
  /VLABELS VARIABLES=satisf cgroup DISPLAY=DEFAULT
  /TABLE cgroup  [ROWPCT.COUNT PCT40.1] BY satisf
  /SLABELS VISIBLE=NO
  /CATEGORIES VARIABLES=satisf cgroup ORDER=A KEY=VALUE EMPTY=INCLUDE TOTAL=YES LABEL="Overall" POSITION=AFTER
  MISSING=EXCLUDE
  /TITLES
   TITLE= 'Overall, how satisfied have you been with this example syntax?'.

DELETE VARIABLES cgroup.

OUTPUT EXPORT
  /CONTENTS  EXPORT=VISIBLE  LAYERS=PRINTSETTING  MODELVIEWS=PRINTSETTING
  /PDF  DOCUMENTFILE=!Quote(!Concat('filepath',!iname,'.pdf'))
     EMBEDBOOKMARKS=YES  EMBEDFONTS=YES.

OUTPUT SAVE
OUTFILE=!Quote(!Concat('filepath',!iname,'.spv'))

OUTPUT CLOSE *. 
OUTPUT NEW.

!ENDDEFINE.

!ess1 inum=1/iname=Name1/ iname2='Name1'/g1= 2,3,4,5,6,7,8,9,10,11,12,13 /g2= 21,22,23,24,25,26,27,29/g3=31,32,33,34,35,36,37,38/g4=41,42,43,44,45/.
!ess1 inum=2 /iname=Name2 /iname2='Name2'/g1= 1,3,4,5,6,7,8,9,10,11,12,13 /g2= 21,22,23,24,25,26,27,29/g3=31,32,33,34,35,36,37,38/g4=41,42,43,44,45/.
!ess1 inum=3 /iname=Name3 /iname2='Name3'/g1= 1,2,4,5,6,7,8,9,10,11,12,13 /g2= 21,22,23,24,25,26,27,29/g3=31,32,33,34,35,36,37,38/g4=41,42,43,44,45/.

2 个答案:

答案 0 :(得分:1)

查看您如何设置此工作流程,您可以暂时为要排除男性的特定机构(?)将INST变量设置为SYSMIS

因此,在您的代码中添加以下内容:

/* Untested */.
TEMP.
DO IF ANY(INST, !g1).
  RECODE INST (ELSE=SYSMIS).
END IF.
CTABLES ...

现在INST变量设置为SYSMISCTABLES默认情况下会在数据的任何表格形式中排除这些情况。

答案 1 :(得分:0)

您需要向宏中添加一个参数,以确定是否过滤掉男性,然后,条件是肯定(!IF!femalesonly eq“是”),生成适当的计算和过滤器语法(然后将其转换为在最后)。