将 SPSS 元数据变量标签、值标签、数据类型等导出到自定义文本文件
Export SPSS metadata variable labels, value labels, data types etc. to custom text file
我们有一个很大的 SPSS 文件,它有 5MB,有大约 1400 个变量。我们正在将所有内容迁移到数据库,为了配置表格和表单等。我们需要 SPSS 文件中的元数据,但采用特定的自定义格式。
所以如果变量视图是这样的:
+--------+------------------+---------+-------+----------+----------------+
| Name | Label | Type | Width | Decimals | Values |
+--------+------------------+---------+-------+----------+----------------+
| PATID | Patient Id | Numeric | 8 | 0 | |
| DOB | Date Of Birth | Date | 11 | 0 | |
| SEX | Sex | String | 1 | 0 | {F, Female}... |
| ICFORM | Informed consent | Numeric | 8 | 0 | {0, No}... |
+--------+------------------+---------+-------+----------+----------------+
我们需要自定义格式的元数据文件,如下所示:
FieldName;Description;DataType;Width;Decimals;Choices
PATID;"Patient Id";Int;8;0;""
DOB;"Date Of Birth";Datetime;11;0;""
SEX;"Sex";radio;1;0;"F = Female, M = Male"
ICFORM;"Informed consent";radio;8;0;"0 = No, 1 = Yes"
我们还有几个 SPSS 文件,所以我希望尽可能使用 SPSS 语法。在 中有人建议使用 OMS
来捕获 dictionary
但我不知道它是如何工作的。当我尝试这个时:
DISPLAY dictionary.
OMS dictionary.
我刚收到一个错误:
Subcommand OMS. Unknown keyword or subcommand: dictionary.
Execution of this command stops.
OMS
确实是你所需要的,但是完整的过程是这样的:
DATASET DECLARE vars.
OMS /SELECT TABLES
/IF COMMANDS=['File Information'] SUBTYPES=['Variable Information']
/DESTINATION FORMAT=SAV NUMBERED=TableNumber_ OUTFILE='vars' .
DATASET DECLARE vals.
OMS /SELECT TABLES
/IF COMMANDS=['File Information'] SUBTYPES=['Variable Values']
/DESTINATION FORMAT=SAV NUMBERED=TableNumber_ OUTFILE='vals' .
display dictionary.
omsend.
您现在将拥有两个包含所有变量的变量定义和值标签的新数据集。
在任何情况下都不需要将元数据导出到新文件中。您还可以从 SPSS 数据文件导入元数据。这样做的命令是:
APPLY DICTIONARY FROM datafilename.sav
/SOURCE VARIABLES = varlist
/TARGET VARIABLES = varlist
/NEWVARS .
您可以在
中找到关于此的完整信息
IBM SPSS Statistics 26 命令语法参考,第 15 章 - 应用字典,p. 167ff
HTH.
此致
乔治
我们有一个很大的 SPSS 文件,它有 5MB,有大约 1400 个变量。我们正在将所有内容迁移到数据库,为了配置表格和表单等。我们需要 SPSS 文件中的元数据,但采用特定的自定义格式。
所以如果变量视图是这样的:
+--------+------------------+---------+-------+----------+----------------+
| Name | Label | Type | Width | Decimals | Values |
+--------+------------------+---------+-------+----------+----------------+
| PATID | Patient Id | Numeric | 8 | 0 | |
| DOB | Date Of Birth | Date | 11 | 0 | |
| SEX | Sex | String | 1 | 0 | {F, Female}... |
| ICFORM | Informed consent | Numeric | 8 | 0 | {0, No}... |
+--------+------------------+---------+-------+----------+----------------+
我们需要自定义格式的元数据文件,如下所示:
FieldName;Description;DataType;Width;Decimals;Choices
PATID;"Patient Id";Int;8;0;""
DOB;"Date Of Birth";Datetime;11;0;""
SEX;"Sex";radio;1;0;"F = Female, M = Male"
ICFORM;"Informed consent";radio;8;0;"0 = No, 1 = Yes"
我们还有几个 SPSS 文件,所以我希望尽可能使用 SPSS 语法。在 OMS
来捕获 dictionary
但我不知道它是如何工作的。当我尝试这个时:
DISPLAY dictionary.
OMS dictionary.
我刚收到一个错误:
Subcommand OMS. Unknown keyword or subcommand: dictionary.
Execution of this command stops.
OMS
确实是你所需要的,但是完整的过程是这样的:
DATASET DECLARE vars.
OMS /SELECT TABLES
/IF COMMANDS=['File Information'] SUBTYPES=['Variable Information']
/DESTINATION FORMAT=SAV NUMBERED=TableNumber_ OUTFILE='vars' .
DATASET DECLARE vals.
OMS /SELECT TABLES
/IF COMMANDS=['File Information'] SUBTYPES=['Variable Values']
/DESTINATION FORMAT=SAV NUMBERED=TableNumber_ OUTFILE='vals' .
display dictionary.
omsend.
您现在将拥有两个包含所有变量的变量定义和值标签的新数据集。
在任何情况下都不需要将元数据导出到新文件中。您还可以从 SPSS 数据文件导入元数据。这样做的命令是:
APPLY DICTIONARY FROM datafilename.sav
/SOURCE VARIABLES = varlist
/TARGET VARIABLES = varlist
/NEWVARS .
您可以在
中找到关于此的完整信息IBM SPSS Statistics 26 命令语法参考,第 15 章 - 应用字典,p. 167ff
HTH.
此致
乔治