Выравнивание набора числовых столбцов, когда columnating данные

В Bash type встроенная оболочка дает информацию об исполняемых вещах: псевдонимы, функции, исполняемые файлы. Посмотрите help type для деталей.

# just check for existence
type -t 'yourfunction' > /dev/null || echo 'error: yourfunction not found'

# explicitly check for given type
[[ "$( type -t 'yourfunction' )" != 'function' ]] && \
    echo 'error: yourfunction not found or is not a function'
4
13.04.2017, 15:36
3 ответа

ОБНОВЛЕНИЕ: добавленный сценарий (не один лайнер, хотя), который позволяет Вам выбирать, какие столбцы Вы хотите выровненный по ширине... Это обслуживает Левое (значение по умолчанию) и Право (не Центр).. Как есть это ожидает, что ВКЛАДКА разграничила поля. Можно изменить выходной разделитель столбца через $S.

RJustCol=(2 3 5)  # Set columns to be right justified.
RJustRex=; Q=$'\x01'; R=$'\x02'; S=" | "
for r in ${RJustCol[@]} ;do  # Build the Right-justify regex.
  RJustRex="${RJustRex}s/^(([^\t]+\t){$((r-1))})([^\t]+)\t/\1\3$R\t/; "
done
sed -r "s/$/\tZ/g; s/^/$Q/; s/\t/\t$Q/g; $RJustRex" file |
  column -t -s $'\t' | 
    sed -r "s/  $Q/$Q/g; s/$Q([^$Q$R]*)$R([^$Q]*)/$S\2\1/g; s/$Q/$S/g; s/Z$//"

Типичный вывод:

| The Lost Art       |   +1255 |  789 | Los                 |     -55 | 
| of the Idle Moment | -159900 | 0123 | Fabulosos Cadillacs | +321987 | 

Примечание:column не работает, поскольку Вы могли бы ожидать, когда у Вас есть пустые ячейки.

Option -n
        By default, the column command will merge multiple adjacent
        delimiters into a single delimiter when using the --t option;
        this option disables that behavior. This option is a Debian
        GNU/Linux extension.

Отсюда на исходный ответ, который связан с, но конкретно не решает tne основную проблему th вопроса..

Вот "острота", которая удовлетворяет целым числам (и позволяет +/-знаки).. "X" силы заполнителя column к правильной клавиатуре последняя ячейка.

sed 's/$/\tX/g' file |column -t |sed -r 's/([-+]?[0-9.]+)( +)/\2\1/g; s/^  //; s/X$//'

Типичный вывод

  +1255  789  011      -55       34
-159900   33  022  +321987  2323566

Если у Вас есть значения плавающие или плавания, смешанные с целыми числами или просто целыми числами, (дополнительное продвижение +/-знаки), немного больше работ перестановки.

sed -r 's/$/\tX/; 
        s/([-+]?[0-9]+\.[0-9]+)\t/\1@\t/g
        s/([-+]?[0-9]+)\t/\1.@\t/g
        s/\./\t./g' file |
  column -t |
    sed -r 's/  \././g
            s/([-+]?[0-9.]+)( +)/\2\1/g
            s/\.@/ /g
            s/@//g
            s/ +X$//'

Типичный вывод

+1255       789   0.11   -55           34
  -15.9900   33   0.22  +321.987  2323566
2
27.01.2020, 20:56

От простой точки я использовал бы awk

column -t filename | awk '{for (i=0; i<NF; i++){l=index($0, $i)+1;printf "%*s ", index($0, $(i+1))-l, $i}printf "%*s\n", index($0, $NF)-l, $NF}'

Это делает для немного шире

2
27.01.2020, 20:56

Похоже, что в новых версиях columnесть опция для выравнивания по правому краю -определенных столбцов:

   -R, --table-right columns
          Right align text in the specified columns.

Как обычно, RHEL/Centos безнадежно устарели, и эта опция пока недоступна в RHEL/Centos 7 (packageutil-linux). Даже RHEL8 , похоже, имеет старую версию.

1
06.04.2020, 08:55

Теги

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