次の出力があります。
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
()幅を取得するために、2番目の文字列をスペースで埋め、%${n}s
スペースを=
。- 列はタブ
\t
で区切られていますが、パイプを介してより見やすくすることができますcolumn -ts'\t'
。 $((n/3))
置換を使用して${n}
行を減らすことができます。
その他のバージョン:
unset IFS; printf "%s\t%*s\n" $(sed 's/$/ =/' test.txt) | tr ' ' =
sed
私が見ることの唯一の欠点は、スケールを縮小するために出力をどこかにパイプする必要があることです。それ以外の場合、これは最もきれいなオプションです。入力ファイルにこれらのいずれかが含まれる可能性がある場合は、[?*
w / bootコマンドを使用する必要があります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 *.......................................
.
.
.