我有以下输出:
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 *.......................................
.
.
.