Qual è il modo più efficiente per convertire dati separati da tabulazione come questo:
a b c d cat
NULL NULL NULL NULL NULL
NULL NULL NULL d d
NULL NULL c NULL c
NULL NULL c d c; d
NULL b NULL NULL b
NULL b NULL d b; d
NULL b c NULL b; c
NULL b c d b; c; d
a NULL NULL NULL a
a NULL NULL d a; d
a NULL c NULL a; c
a NULL c d a; c; d
a b NULL NULL a; b
a b NULL d a; b; d
a b c NULL a; b; c
a b c d a; b; c; d
Qualcosa di simile a questo:
a | b | c | d | cat
-----+------+------+------+-----------
NULL | NULL | NULL | NULL | NULL
NULL | NULL | NULL | d | d
NULL | NULL | c | NULL | c
NULL | NULL | c | d | c; d
NULL | b | NULL | NULL | b
NULL | b | NULL | d | b; d
NULL | b | c | NULL | b; c
NULL | b | c | d | b; c; d
a | NULL | NULL | NULL | a
a | NULL | NULL | d | a; d
a | NULL | c | NULL | a; c
a | NULL | c | d | a; c; d
a | b | NULL | NULL | a; b
a | b | NULL | d | a; b; d
a | b | c | NULL | a; b; c
a | b | c | d | a; b; c; d
Attualmente uso Notepad ++ come segue:
- Converti le schede in spazi
- Allinea i dati manualmente
- Utilizzare la modalità colonna per inserire i tubi
Il secondo passo è il più noioso e preferirei che almeno questa parte fosse automatizzata.
Nota: utilizzo un browser mentre lavoro e talvolta ho un editor di testo aperto a fianco. La soluzione efficiente è quella che richiede il minimo sforzo. Posso usare:
- Notepad ++
- Editor di testo generico con regexp trova / sostituisci supporto
- JavaScript digitato nella console del browser
- Servizio web online
- PHP da riga di comando (
php -a
)
awk
sceneggiatura semplice .
{{(⊃⍵)⍪⍉⍪↑¨↓⍉↑1↓⍵}s¨'⎕T'⎕T¨(s←1↓¨⊢⊂⍨⊢=⊃)¯1⌽⍵}
sembra abbastanza carino su cui lavorare, eh?)