2016-04-07 28 views
1

例如,我有一列名稱不同的用逗號分隔的人(全部在1個單元格中)Ben Lee,Paul Loy,Boy Lim。我想將每個名稱分成不同的列。我將如何做到這一點? (在SPSS語法中)。SPSS字符串提取

+0

目前與char.index和char.substr,沒有更迭尚未 – don

回答

0
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". 
1

this thread與潛在的解決方案(S)。也就是說,信貸大衛Marso和喬恩·佩克:

* 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. 

或可替代蟒蛇的解決方案:

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)". 
+0

這是大衛Marso,而不是馬科試驗。 .. –