Использовать 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
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
См. также:
Для относительно небольших файлов, (где длина в байтах меньше, чем 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
Обратите внимание, как числа выровнены по правому краю .