一个shell工具,以“制表”输入数据


33

很久以前,我记得使用一个命令,将其输入到格式良好的表中。

例如,对于此输入,

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

输出将类似于以下内容:

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

我想知道这个工具的名字。

Answers:


35

使用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

我喜欢手册页:“ 专栏列表”。类似于“ tablify”。
里德,

0

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

对于相对较小的文件(以字节为单位的长度小于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

请注意数字是如何对齐的。

By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.