这是 的输出cal
。向每个单元格附加附加内容的最简单方法是什么<SPACE>
?
June 2021
Su Mo Tu We Th Fr Sa
1 2 3 4 5
6 7 8 9 10 11 12
13 14 15 16 17 18 19
20 21 22 23 24 25 26
27 28 29 30
预期结果:
June 2021
Su Mo Tu We Th Fr Sa
1 2 3 4 5
6 7 8 9 10 11 12
13 14 15 16 17 18 19
20 21 22 23 24 25 26
27 28 29 30
答案1
这可能是您想要做的:
$ cal | awk 'NR>1{gsub(/.../,"& ")}1'
June 2021
Su Mo Tu We Th Fr Sa
1 2 3 4 5
6 7 8 9 10 11 12
13 14 15 16 17 18 19
20 21 22 23 24 25 26
27 28 29 30
请注意,它不会在每行末尾的“单元格”中添加空白,也不会在月+年行的“单元格”后面添加额外的空白。
答案2
使用awk
:
$ cal | awk '{ gsub(/[^ ] | /, "& ") }1'
或使用sed
:
$ cal | sed -E 's/[^ ] | /& /g'
June 2021
Su Mo Tu We Th Fr Sa
1 2 3 4 5
6 7 8 9 10 11 12
13 14 15 16 17 18 19
20 21 22 23 24 25 26
27 28 29 30
答案3
GNU awk
cal | cat | gawk -v FIELDWIDTHS="3 3 3 3 3 3 2" 'NR > 1 {$1 = $1} 1'