『壹』 Linux腳本:for循環 {1..100}和$(seq 1 100)兩種列表模式,什麼區別
{x..y[..i]} 這種形式是bash內部的一種表達式,會生成一個空格分隔的數字序列字元串
$(cmd) 或 `cmd` 是bash的另一種表達式,表示把cmd的輸出作為一個字元串
因此可見, 使用$(seq x y)的方式系統會啟動一個新的進程運行cmd命令,相對於{x..y}的方式,速度上會有劣勢,同時內存佔用也會更多,此外還依賴/bin/seq命令的存在。
『貳』 用shell如何寫遞增的程序
可以使用 seq 命令產生遞增序列,也可以使用循環遞增。
來兩個shell代碼示例:
foriin`seq10`
do
echo$i
done
i=0
while[$i-lt10]
do
leti+=1
echo$i
done
『叄』 shell中如何設置自增的變數
loop=$(( $loop + 1 ))echo "$i "echo "num : $loop"done注意:loop=`expr $loop + 1` ,loop變數左右 不能 有空格,並且 不是 單引號;另外,對於固定次數的循環,可以通過seq命令來實現,就不需要變數的自增了;實例如下:
『肆』 shell腳本顯示0,1,1,2,3,5,8,13
#!/bin/bash
b=0;
a=1;
for i in `seq 0 9`;do
echo $b
b=`expr $b + $a`
a=`expr $b - $a`
done
#顯示前10個
#如果你想顯示100個只需改成 seq 0 99
『伍』 在SHELL腳本中,如何設置讓某個命令執行5次
ls
ls
ls
ls
ls
或者循環5次
for i in `seq 5`;do
ls
done
『陸』 linux shell 麻煩幫我詳細解說一下這個腳本。正在學習shell
1. NF,NR 都是awk的內置變數。
知道英文縮寫就知道意思了。NF: Number of Field (欄位數),NR: Number of Record (記錄數)。
2. while read filenum record
對每一個讀入的 filenum 與 record 變數值都送入while循環。根據語法,while後面是邏輯判斷,read返回不為空(即邏輯真)就進入並執行while循環。
3. for a in `seq 3 $filenum`
seq產生整數數列,這里就是產生3到$filenum范圍的整數序列,sed的具體用法你網上搜索一下就清楚了。filenum就是前面read讀進來的(用戶輸入的)。這個for循環就是對於seq產生的整數數列中的每個數都執行。
4. ${b}就代表變數b的值。加上{}只是為了圈定變數范圍。沒什麼其他意思,這也不是什麼正則表達式。 \是轉義,$是求值,\$表示就輸出$,轉義消除了$求值的功能。\$${a} 表示先求變數a的值,然後將這個值作為變數。最後就是輸出 ${變數a的值}
5. c=" sed -n '${record}p' abc.txt "
${record}就表示求變數 record 的值,不加{}就表示求變數 recordp 的值。{}用於圈定變數范圍。
『柒』 shell腳本如何編寫
#!/bin/sh
#filename:sumint.sh
sum=0
read -p "Input the number:" A
for x in `seq $A`
do
sum=$(($sum+$x))
done
echo $sum
『捌』 shell編程 shell腳本 跪求大神解答 高懸賞 求解答
shell腳本如下:
#!/bin/bash
for n in {0..49}
do
filename=`printf "file%02d.t" $n`
touch $filename
chmod +w $filename
let mod="$n % 2"
if [ $mod -eq 0 ]; then #even
eval echo {1..$n} | awk '{for(i=1;i<=$NF;i++)sum+=$i}END{print sum}' >$filename
else #odd
echo "`pwd`/$filename" >>$filename
date >>$filename
fi
done
『玖』 shell腳本如何用for循環做遞減
用seq命令可以生成遞減序列:
foriin$(seq10-11)
do
echo$i
done
seq命令說明:
基本用法
seq [選項]... 尾數
seq [選項]... 首數 尾數
seq [選項]... 首數 增量 尾數
以指定增量從首數開始列印數字到尾數。
對於第三種模式,當首數大於尾數時,增量需要指定為負數。
『拾』 shell腳本生成[4,9]范圍內的隨機整數,包含邊界值4和9,並將隨機數序列存放在一個數組中,腳本實現
#!/bin/sh
declare -a arr #聲明arr為數組
arr=(`seq 4 9 | awk 'BEGIN{srand();ORS=" "} {b[rand()]=$0} END{for(x in b) print b[x]}'`)
echo ${arr[*]} #列印數組array的所有元素
exit 0
說明:
生成[4,9]范圍內不重復的隨機整數,並保存到數組arr中。
seq 4 9 用於生成4~9的整數序列(包含邊界值4和9)。
awk中的rand() 函數用於隨機產生一個0到1之間的小數值(保留小數點後6位)。
由於rand()只生成一次隨機數,要使用srand() 函數使隨機數滾動生成(括弧里留空即默認採用當前時間作為隨機計數器的種子)。這樣以秒為間隔,隨機數就能滾動隨機生成了。
限制:
由於以秒為間隔,所以如果快速連續運行兩次腳本(1s內),你會發現生成的隨機數還是一樣的。