Mesclar várias linhas coluna por coluna com base na coluna 1 - mesmo arquivo?

2

Estou tentando organizar um arquivo CSV com 30 colunas e 1.000 linhas. Eu quero concatenar as linhas coluna por coluna se a primeira coluna é a mesma, usando uma linha vertical (|).

Entrada:

3,XX,YY,123,1234,MM,-,,DD,1235,XC
3,XM,YM,123,1234,MD,-,A,FD,1233,XC
3,XN,YN,123,1234,MM,-,,ED,1235,XC

Saída:

3,XX|XM|XN,YY|YM|YN,123,1234,MM|MD,-,A,DD|FD|ED,1235|1233,XC

Por isso, quero apenas concatenar os diferentes valores.

Eu dei uma olhada neste tópico mas não foi útil para o meu problema?

    
por ness 06.08.2018 / 06:32

1 resposta

1

Por que não foi o thread é útil? Após pequenas modificações, tente

    awk -F, '
    function p(n,A) {s = n
                     for (i=2; i<=NF; i++)  {s = s FS  A[i]
                                             A[i] = $i
                                            }
                     if (n) print s
                    }


    $1==n           {for (i=2; i<=NF; i++) if (A[i] !~ "[|]*" $i "[|]*") A[i] = A[i] "|" $i
                     next
                    }

                    {p(n,A)
                     n = $1
                    }

    END             {p(n,A)
                    }
    ' file
3,XX|XM|XN,YY|YM|YN,123,1234,MM|MD,-,|A,DD|FD|ED,1235|1233,XC
    
por 06.08.2018 / 08:48