1

我正在使用 SPSS 20。在我的数据集中是一个字符串变量列表,我想将其重新编码为数字。最初我希望它们被重新编码成它们自己。我意识到这是不可能的,因为 SPSS 逐个遍历数据集,并且一个变量一次只能有一种类型。所以我希望将它们重新编码为新变量,但后缀为_rec.

DO REPEAT var = var_1 var_2 ... var_n.
  RECODE var (CONVERT) INTO var_rec.
END REPEAT. 

但这只会创建一个新变量var_rec而不是几个新变量。

我还尝试编写一个解决方法:

COMPUTE Job_2
STRING Job(A20)
    DO REPEAT var = var_1 var_2 ... var_n.
COMPUTE var = Job. 
RECODE Job (CONVERT) INTO Job_2.
DELETE VARIABLES var.
COMPUTE var = Job_2.  
END REPEAT. 

但这不起作用,因为DELETE VARIABLES不能在DO REPEAT循环中使用。

所以我回到我原来的问题。

4

1 回答 1

0

你说它们(字符串变量)不能被重新编码成它们自己,但它们可以使用ALTER TYPE

ALTER TYPE var_1 var_2 var_3 (F8.2). 

其中 F8.2 是宽度为 8 和 2 个小数点的数值变量。

您可以使用DO REPEAT多个替代变量列表,如下所示:

DO REPEAT Old = var_1 var_2 var_3
    /New = var1_rec var2_rec var3_rec.
  RECODE Old (CONVERT) INTO New.
END REPEAT PRINT. 

扩展出来相当于:

RECODE var_1 (CONVERT) into var1_rec.
RECODE var_2 (CONVERT) into var2_rec.
RECODE var_3 (CONVERT) into var3_rec.

但是,如果您要这样做,那么您可以RECODE直接在命令中执行此操作,如下所示:

RECODE var_1 var_2 var_3 (CONVERT) INTO var1_rec var2_rec var3_rec.

这两种方法都假定原始变量都是字符串变量(具有任何不同的宽度)。

请注意该函数的确切CONVERT 作用,即获取一个字符串变量(包含存储为字符串的数值)并将其转换为数值格式变量。所以输入变量总是一个字符串,输出数字。

于 2015-08-03T11:25:33.537 回答