Инструмент оболочки к “tablify” входным данным

Набор /bin/false как оболочка в /etc/passwd

33
30.07.2011, 15:49
3 ответа

Использовать column -t. столбец является частью 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
35
27.01.2020, 19:37
  • 1
    мне нравится страница справочника: "списки columnate". Подобный "tablify". –  Reid 31.07.2011, 01:56

awkрешение для стандартного ввода

Поскольку columnне соответствует POSIX, возможно, это:

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
)

Испытание:

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

Тестовые команды:

mycolumn file
mycolumn <file
mycolumn - <file

Вывод для всех:

      12   1234      1
12345678      1    123
    1234 123456 123456

См. также:

0
27.01.2020, 19:37

Для относительно небольших файлов, (где длина в байтах меньше, чем getconf ARG_MAX), а размеры входных данных более или менее известны, (скажем, ни одно имя фрукта не превышает 18 букв ), printfможет быть полезно, вот пример bash:

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

Выход:

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

Обратите внимание, как числа выровнены по правому краю .

0
27.01.2020, 19:37

Теги

Похожие вопросы