Jak wyrównać kolumny w danych wyjściowych polecenia UNIX?


21

Wcześniej znałem polecenie - rzeczywiste polecenie zapamiętaj, a nie magię sed / awk - które sformatowało dane wejściowe, aby były wyrównane w kolumnach. Na przykład, jeśli uruchomiłeś:

% echo -e "aaaaa bbbbbbb\ncc ddd"
aaaaa bbbbbbb
cc ddd

Ale jeśli uruchomiłeś dane wyjściowe za pomocą polecenia, o którym zapomniałem nazwy:

% echo -e "aaaaa bbbbbbb\ncc ddd" | mystery_command
aaaaa    bbbbbbb
cc       ddd

Czy ktoś zna nazwę tego polecenia?

Odpowiedzi:



0

awk rozwiązanie, które dotyczy stdin

Ponieważ columnnie jest POSIX, może to jest:

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
)

Test:

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

Polecenia testowe:

mycolumn file
mycolumn <file
mycolumn - <file

Wyjście dla wszystkich:

      12   1234      1
12345678      1    123
    1234 123456 123456

Zobacz też:

Korzystając z naszej strony potwierdzasz, że przeczytałeś(-aś) i rozumiesz nasze zasady używania plików cookie i zasady ochrony prywatności.
Licensed under cc by-sa 3.0 with attribution required.