sql >> Base de Datos >  >> RDS >> Mysql

Extraer campos específicos del archivo de texto

Esto es similar a la respuesta de MvG, pero no requiere gawk 4 y por lo tanto usa -F como se sugiere en esa respuesta. También muestra una técnica para listar los campos deseados e iterar sobre la lista. Esto puede hacer que el código sea más fácil de mantener si hay una lista grande.

#!/usr/bin/awk -f
BEGIN {
    col_list = "colour shape size" # continuing with as many as desired for output
    num_cols = split(col_list, cols)
    FS = OFS = ","
}

NR==1 {
    for (i = 1; i <= NF; i++) {
        p[$i] = i # remember column for name
    }
    # next # enable this line to suppress headers.
}

{
    delim = ""
    for (i = 1; i <= num_cols; i++) {
        printf "%s%s", delim, $p[cols[i]]
        delim = OFS
    }
    printf "\n"
}