SPSS字符串提取



我有一列用逗号分隔的不同人名,例如(都在一个单元格中)Ben Lee、Paul Loy、Boy Lim。我想把每个名字分成不同的列。我该怎么做?(在SPSS语法中)。

请参阅此线程中的潜在解决方案。也就是说,归功于David Marso和Jon Peck:

 * General Parser *. 
DATA LIST / X 1-80 (A). 
BEGIN DATA 11-0101-423-7384 
END DATA. 
VECTOR NUMS(10). 
COMPUTE #0=0. 
LOOP. 
COMPUTE #1=INDEX(X,'-'). 
COMPUTE #0=#0+1. 
IF #1>0 NUMS(#0)=NUMBER(SUBSTR(X,1,#1-1),F8). 
COMPUTE X=SUBSTR(X,#1+1). 
END LOOP IF #1=0. 
COMPUTE NUMS(#0)=NUMBER(X,F8). 
MATCH FILES FILE * / DROP X. 
LIST. 

或者另一种python解决方案:

data list free /x(a13). 
begin data. 
1,13,5,6,99,8 
end data. 
dataset name data. 
begin program. 
def split(v): 
  return v.split(',') 
end program. 
spssinc trans result = v1 to v6 
/formula "split(x)". 
do repeat TXTname="Ben Lee" "Paul Loy" "Boy Lim"/VRname=BenLee PaulLoy BoyLim.
compute VRname=index(OriginalColumnName, TXTname)>0.
end repeat.

如果有更多的名称,您可能更喜欢使用标准变量名称,并在标签中添加实际名称:

do repeat TXTname="Ben Lee" "Paul Loy" "Boy Lim"/VRname=Name01 to Name03.
compute VRname=index(OriginalColumnName, TXTname)>0.
end repeat.
variable labels 
Name01 "Ben Lee"
Name02 "Paul Loy"
Name03 "Boy Lim".

最新更新