从 bash 命令输出绘制直方图

从 bash 命令输出绘制直方图

我有以下输出:

2015/1/7    8
2015/1/8    49
2015/1/9    40
2015/1/10   337
2015/1/11   11
2015/1/12   3
2015/1/13   9
2015/1/14   102
2015/1/15   62
2015/1/16   10
2015/1/17   30
2015/1/18   30
2015/1/19   1
2015/1/20   3
2015/1/21   23
2015/1/22   12
2015/1/24   6
2015/1/25   3
2015/1/27   2
2015/1/28   16
2015/1/29   1
2015/2/1    12
2015/2/2    2
2015/2/3    1
2015/2/4    10
2015/2/5    13
2015/2/6    2
2015/2/9    2
2015/2/10   25
2015/2/11   1
2015/2/12   6
2015/2/13   12
2015/2/14   2
2015/2/16   8
2015/2/17   8
2015/2/20   1
2015/2/23   1
2015/2/27   1
2015/3/2    3
2015/3/3    2

我想画一个直方图

2015/1/7  ===
2015/1/8  ===========
2015/1/9  ==========
2015/1/10 ====================================================================
2015/1/11 ===
2015/1/11 =
...

你知道是否有 bash 命令可以让我这样做吗?

答案1

perl

perl -pe 's/ (\d+)$/"="x$1/e' file
  • e导致对表达式进行求值,因此我会重复使用(与 匹配的数字)=的值。$1(\d+)
  • 你可以做"="x($1\/3)而不是"="x$1缩短线路。 (/由于我们正处于替换命令的中间,因此被转义。)

bash(灵感来自这个答案):

while read d n 
do 
    printf "%s\t%${n}s\n" "$d" = | tr ' ' '=' 
done < test.txt
  • printf$n 使用空格填充第二个字符串以获得( )的宽度%${n}s,然后我将空格替换为=
  • 列使用制表符 ( \t) 分隔,但您可以通过管道连接到 使其更美观column -ts'\t'
  • 您可以使用$((n/3))代替来${n}缩短线路。

另一个版本:

unset IFS; printf "%s\t%*s\n" $(sed 's/$/ =/' test.txt) | tr ' ' =

sed我看到的唯一缺点是,如果你想缩小规模,你需要将 的输出通过管道传输到某个地方,否则这是最干净的选择。如果您的输入文件有可能包含其中之一,[?*则应使用 w/ 引导命令set -f;

答案2

试试这个

perl -lane 'print $F[0], "\t", "=" x ($F[1] / 5)' file

说明:

  • -a是一个显式split()@F数组,我们得到的值是$F[n]
  • x就是告诉perl打印一个字符N次
  • ($F[1] / 5):在这里我们得到数字并将其除以 5 以获得漂亮的打印输出(简单的算术)

答案3

轻松搭配awk

awk '{$2=sprintf("%-*s", $2, ""); gsub(" ", "=", $2); printf("%-10s%s\n", $1, $2)}' file

2015/1/7 ========
2015/1/8 =================================================
2015/1/9 ========================================
..
..

或者用我最喜欢的编程语言

python3 -c 'import sys
for line in sys.stdin:
  data, width = line.split()
  print("{:<10}{:=<{width}}".format(data, "", width=width))' <file

答案4

你可以用做类似的事情酒吧动词在磨坊主

$ mlr --nidx --repifs --ofs tab bar -f 2 file
2015/1/7    ***.....................................
2015/1/8    *******************.....................
2015/1/9    ****************........................
2015/1/10   ***************************************#
2015/1/11   ****....................................
2015/1/12   *.......................................
.
.
.

相关内容