Un outil shell pour “tablify” les données d'entrée


33

Il y a longtemps, je me souviens d'avoir utilisé une commande qui en fait un tableau bien formaté.

Par exemple, pour cette entrée,

apple 1 100
orange 20 19
pineapple 1000 87
avocado 4 30

Le résultat sera similaire à ceci:

apple     1    100
orange    20   19
pineapple 1000 87
avocado   4    30

J'aimerais connaître le nom de cet outil.

Réponses:


35

Utilisez column -t. column fait partie d' util-linux .

$ column -t <<END
> apple 1 100
> orange 20 19
> pineapple 1000 87
> avocado 4 30
> END
apple      1     100
orange     20    19
pineapple  1000  87
avocado    4     30

J'aime la page de manuel: " columnate lists". Similaire à "tablify".
Reid

0

awk solution qui traite stdin

Puisque columnn'est pas POSIX, c'est peut-être:

mycolumn() (
  file="${1:--}"
  if [ "$file" = - ]; then
    file="$(mktemp)"
    cat >"${file}"
  fi
  awk '
  FNR == 1 { if (NR == FNR) next }
  NR == FNR {
    for (i = 1; i <= NF; i++) {
      l = length($i)
      if (w[i] < l)
        w[i] = l
    }
    next
  }
  {
    for (i = 1; i <= NF; i++)
      printf "%*s", w[i] + (i > 1 ? 1 : 0), $i
    print ""
  }
  ' "$file" "$file"
  if [ "$file" = - ]; then
    rm "$file"
  fi
)

Tester:

printf '12 1234 1
12345678 1 123
1234 123456 123456
' > file

Commandes de test:

mycolumn file
mycolumn <file
mycolumn - <file

Sortie pour tous:

      12   1234      1
12345678      1    123
    1234 123456 123456

Voir également:


0

Pour des fichiers relativement petits (où la longueur en octets est inférieure à getconf ARG_MAX) et où les tailles d'entrée sont plus ou moins connues (supposons qu'aucun nom de fruit ne dépasse 18 lettres) printfpeut être utile, voici un bashexemple:

 printf '%-20s %5s %5s\n' $(<file.txt)

Sortie:

apple                    1   100
orange                  20    19
pineapple             1000    87
avocado                  4    30

Notez comment les chiffres sont justifiés à droite .

En utilisant notre site, vous reconnaissez avoir lu et compris notre politique liée aux cookies et notre politique de confidentialité.
Licensed under cc by-sa 3.0 with attribution required.