4

私はより深いレベルで bash を学ぼうとしており、乗算表を作成することにしました。私は次のステートメントで機能を持っています:

echo $[{1..10}*{1..10}]

しかし、それは私に次の出力を与えます:

1 2 3 4 5 6 7 8 9 10 2 4 6 8 10 12 14 16 18 20 3 6 9 12 15 18 21 24 27 30 4 8 12 16 20 24 28 32 36 40 5 10 15 20 25 30 35 40 45 50 6 12 18 24 30 36 42 48 54 60 7 14 21 28 35 42 49 56 63 70 8 16 24 32 40 48 56 64 72 80 9 18 27 36 45 54 63 72 81 90 10 20 30 40 50 60 70 80 90 100

1つのステートメントのみを使用して、次のようにこの出力をフォーマットする方法はありますか(ループでこれを行う方法を理解できますが、それは面白くありません:p)

1 2 3 4 5 6 7 8 9 10 
2 4 6 8 10 12 14 16 18 20 
3 6 9 12 15 18 21 24 27 30 
4 8 12 16 20 24 28 32 36 40 
5 10 15 20 25 30 35 40 45 50 
6 12 18 24 30 36 42 48 54 60 
7 14 21 28 35 42 49 56 63 70 
8 16 24 32 40 48 56 64 72 80 
9 18 27 36 45 54 63 72 81 90 
10 20 30 40 50 60 70 80 90 100

1つのステートメントで行うことさえ可能ですか、それともループする必要がありますか?

4

2 に答える 2

11

ループを使用せずに適切な出力を得るには、次の行を使用します。

echo $[{1..10}*{1..10}] | xargs -n10 | column -t

出力:

1   2   3   4   5   6   7   8   9   10
2   4   6   8   10  12  14  16  18  20
3   6   9   12  15  18  21  24  27  30
4   8   12  16  20  24  28  32  36  40
5   10  15  20  25  30  35  40  45  50
6   12  18  24  30  36  42  48  54  60
7   14  21  28  35  42  49  56  63  70
8   16  24  32  40  48  56  64  72  80
9   18  27  36  45  54  63  72  81  90
10  20  30  40  50  60  70  80  90  100

アップデート

論理的な次のステップとして、この掛け算の表に可変範囲を持たせることができるかどうかをここで尋ねました。この助けを借りて、私の答えは変数 ( $boundary) 範囲で機能し、非常に読みやすいままです:

boundary=4; eval echo $\[{1..$boundary}*{1..$boundary}\] | xargs -n$boundary | column -t

出力:

1  2  3   4
2  4  6   8
3  6  9   12
4  8  12  16

また、$[..]算術表記は非推奨であり、$((...))代わりに使用する必要があることに注意してください。

boundary=4; eval eval echo "$\(\({1..$boundary}*{1..$boundary}\)\)" | xargs -n$boundary | column -t

于 2011-04-16T23:34:54.273 に答える
3

printfビルトインは、すべての引数を出力するために必要な回数だけそのフォーマットを繰り返します。

printf '%d %d %d %d %d %d %d %d %d %d\n' $[{1..10}*{1..10}]

%d少しの繰り返しを避けたい場合は、よりトリッキーです。

printf "$(echo %$[{1..10}*0]d)\\n" $[{1..10}*{1..10}]

プロダクション コードでは、ループを使用します。

于 2011-04-17T00:01:58.007 に答える