2016-04-07 18 views
1

Ich habe eine Spalte mit Namen von verschiedenen Personen durch Komma getrennt, zum Beispiel (alle in 1 Zelle) Ben Lee, Paul Loy, Boy Lim. Ich möchte jeden Namen in verschiedene Spalten aufteilen. Wie werde ich es tun? (in SPSS-Syntax).SPSS String-Extraktion

+0

derzeit mit char.index und char.substr experimentieren, ohne Erfolg noch – don

Antwort

0
do repeat TXTname="Ben Lee" "Paul Loy" "Boy Lim"/VRname=BenLee PaulLoy BoyLim. 
compute VRname=index(OriginalColumnName, TXTname)>0. 
end repeat. 

Wenn es viele weitere Namen sind Sie vielleicht lieber stattdessen Standardvariablennamen verwenden, und fügen Sie die tatsächlichen Namen in den Etiketten statt:

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

Siehe this thread mit potentiellen Lösung (en). Das heißt, Kredit David Marso und 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. 

Oder alternativ eine Python-Lösung:

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

Das David Marso ist, nicht Marco. .. –

Verwandte Themen