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