您好,登錄后才能下訂單哦!
這篇文章主要講解了“如何使用Linux seq命令生成數(shù)字序列”,文中的講解內(nèi)容簡單清晰,易于學(xué)習(xí)與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學(xué)習(xí)“如何使用Linux seq命令生成數(shù)字序列”吧!
Linux 的 seq 命令可以以閃電般的速度生成數(shù)字列表,而且它也易于使用而且靈活。
在 Linux 中生成數(shù)字列表的最簡單方法之一是使用 seq
(系列)命令。其最簡單的形式是,seq
接收一個數(shù)字參數(shù),并輸出從 1 到該數(shù)字的列表。例如:
$ seq 512345
除非另有指定,否則 seq
始終以 1 開頭。你可以在最終數(shù)字前面插上不同數(shù)字開始一個序列。
$ seq 3 5345
你還可以指定增量步幅。假設(shè)你要列出 3 的倍數(shù)。指定起點(diǎn)(在此示例中為第一個 3 ),增量(第二個 3)和終點(diǎn)(18)。
$ seq 3 3 18369121518
你可以選擇使用負(fù)增量(即減量)將數(shù)字從大變小。
$ seq 18 -3 3181512963
seq
命令也非???。你或許可以在 10 秒內(nèi)生成一百萬個數(shù)字的列表。
$ time seq 1000000123……9999989999991000000 real 0m9.290s <== 9+ secondsuser 0m0.020ssys 0m0.899s
另一個非常有用的選項是使用分隔符。你可以插入逗號、冒號或其他一些字符,而不是在每行上列出單個數(shù)字。-s
選項后跟要使用的字符。
$ seq -s: 3 3 183:6:9:12:15:18
實際上,如果只是希望將數(shù)字列在一行上,那么可以使用空格代替默認(rèn)的換行符。
$ seq -s' ' 3 3 183 6 9 12 15 18
從生成數(shù)字序列到進(jìn)行數(shù)學(xué)運(yùn)算似乎是一個巨大的飛躍,但是有了正確的分隔符,seq
可以輕松地傳遞給 bc
進(jìn)行計算。例如:
$ seq -s* 5 | bc120
該命令中發(fā)生了什么?讓我們來看看。首先,seq
生成一個數(shù)字列表,并使用 *
作為分隔符。
$ seq -s* 51*2*3*4*5
然后,它將字符串傳遞給計算器(bc
),計算器立即將數(shù)字相乘。你可以在不到一秒的時間內(nèi)進(jìn)行相當(dāng)龐大的計算。
$ time seq -s* 117 | bc39699371608087208954019596294986306477904063601683223011297484643104\22041758630649341780708631240196854767624444057168110272995649603642\560353748940315749184568295424000000000000000000000000000 real 0m0.003suser 0m0.004ssys 0m0.000s
你只能選擇一個分隔符,因此計算將非常有限。而單獨(dú)使用 bc
可進(jìn)行更復(fù)雜的數(shù)學(xué)運(yùn)算。此外,seq
僅適用于數(shù)字。要生成單個字母的序列,請改用如下命令:
$ echo {a..g}a b c d e f g
感謝各位的閱讀,以上就是“如何使用Linux seq命令生成數(shù)字序列”的內(nèi)容了,經(jīng)過本文的學(xué)習(xí)后,相信大家對如何使用Linux seq命令生成數(shù)字序列這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關(guān)知識點(diǎn)的文章,歡迎關(guān)注!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。