Linux 的 seq 命令可以以閃電般的速度生成數(shù)字列表,而且它也易于使用而且靈活。
在 Linux 中生成數(shù)字列表的最簡單方法之一是使用 seq(系列sequence)命令。其最簡單的形式是,seq 接收一個數(shù)字參數(shù),并輸出從 1 到該數(shù)字的列表。例如:
$ seq 5
1
2
3
4
5
除非另有指定,否則 seq 始終以 1 開頭。你可以在最終數(shù)字前面插上不同數(shù)字開始一個序列。
$ seq 3 5
3
4
5
指定增量
你還可以指定增量步幅。假設(shè)你要列出 3 的倍數(shù)。指定起點(在此示例中為第一個 3 ),增量(第二個 3)和終點(18)。
$ seq 3 3 18
3
6
9
12
15
18
你可以選擇使用負(fù)增量(即減量)將數(shù)字從大變小。
$ seq 18 -3 3
18
15
12
9
6
3
seq 命令也非???。你或許可以在 10 秒內(nèi)生成一百萬個數(shù)字的列表。
$ time seq 1000000
1
2
3
…
…
999998
999999
1000000
real 0m9.290s <== 9+ seconds
user 0m0.020s
sys 0m0.899s
使用分隔符
另一個非常有用的選項是使用分隔符。你可以插入逗號、冒號或其他一些字符,而不是在每行上列出單個數(shù)字。-s 選項后跟要使用的字符。
$ seq -s: 3 3 18
3:6:9:12:15:18
實際上,如果只是希望將數(shù)字列在一行上,那么可以使用空格代替默認(rèn)的換行符。
$ seq -s' ' 3 3 18
3 6 9 12 15 18
開始數(shù)學(xué)運算
從生成數(shù)字序列到進(jìn)行數(shù)學(xué)運算似乎是一個巨大的飛躍,但是有了正確的分隔符,seq 可以輕松地傳遞給 bc 進(jìn)行計算。例如:
$ seq -s* 5 | bc
120
該命令中發(fā)生了什么?讓我們來看看。首先,seq 生成一個數(shù)字列表,并使用 * 作為分隔符。
$ seq -s* 5
1*2*3*4*5
然后,它將字符串傳遞給計算器(bc),計算器立即將數(shù)字相乘。你可以在不到一秒的時間內(nèi)進(jìn)行相當(dāng)龐大的計算。
$ time seq -s* 117 | bc
39699371608087208954019596294986306477904063601683223011297484643104\
22041758630649341780708631240196854767624444057168110272995649603642\
560353748940315749184568295424000000000000000000000000000
real 0m0.003s
user 0m0.004s
sys 0m0.000s
局限性
你只能選擇一個分隔符,因此計算將非常有限。而單獨使用 bc 可進(jìn)行更復(fù)雜的數(shù)學(xué)運算。此外,seq 僅適用于數(shù)字。要生成單個字母的序列,請改用如下命令:
$ echo {a..g}
a b c d e f g
總結(jié)
以上所述是小編給大家介紹的使用 Linux seq 命令生成數(shù)字序列,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!