一、shell流程控制
1.1 if else
1.第一种方式:
if condition
then
command1
command2
...
commandN
fi
2.第二种方式(写成一行(适用于终端命令提示符))
if condition; then command1; fi
3.第三种方式(在shell中,如果else分支没有语句执行,就不要写这个else,如第一种方式 )
if condition
then
command1
command2
...
commandN
else
command
fi
4.第四种方式
if condition1
then
command1
elif condition2
then
command2
else
commandN
fi
1.2 for 循环
1.第一种方式
for var in item1 item2 ... itemN
do
command1
command2
...
commandN
done
或写成一行:
for var in item1 item2 ... itemN; do command1; command2… done;
2.第二种方式(与c语言类似,但不完全相同)
for((assignment;condition:next));do
command_1;
command_2;
commond_..;
done;
#通常情况下 shell 变量调用需要加 $,但是 for 的 (()) 中不需要,下面来看一个例子:
for((i=1;i<=5;i++));do
echo "这是第 $i 次调用";
done;
#注意:如果要在循环体中进行 for 中的 next 操作,记得变量要加 $,不然程序会变成死循环。
3.第三种方法(使用linux中seq命令)
for var in `seq m n`
do
command1
command2
...
commandN
done
#seq m n:是产生m到n的之间的所有整数,其中n>m;例如:seq 1 100:产生1到100之间的所有整数(包括1和100)
#具体的seq命令的详解可看:https://www.cnblogs.com/ginvip/p/6351720.html
1.3 while 语句
while循环用于不断执行一系列命令,也用于从输入文件中读取数据;命令通常为测试条件。其格式为:
1.有限循环
while condition
do
command
done
举个例子:
int=1
while(( $int<=5 ))
do
echo $int
let "int++"
done
2.无限循环
while :
do
command
done
或
while true
do
command
done
或
for (( ; ; ))
1.4 until 循环
until 循环执行一系列命令直至条件为 true 时停止。
until 循环与 while 循环在处理方式上刚好相反。
一般 while 循环优于 until 循环,但在某些时候—也只是极少数情况下,until 循环更加有用。
until 语法格式:
until condition
do
command
done
1.5 case 多选择语句
可以用case语句匹配一个值与一个模式,如果匹配成功,执行相匹配的命令。case语句格式如下:
case 值 in
模式1)
command1
command2
...
commandN
;;
模式2)
command1
command2
...
commandN
;;
esac #case 反过来,作为case的结束标记
:'
case工作方式如上所示。取值后面必须为单词in,每一模式必须以右括号结束。取值可以为变量或常数。
匹配发现取值符合某一模式后,其间所有命令开始执行直至 ;;。
取值将检测匹配的每一个模式。一旦模式匹配,则执行完匹配模式相应命令后不再继续其他模式。
如果无一匹配模式,使用星号 * 捕获该值,再执行后面的命令。
'
#举个例子:
echo '输入 1 到 4 之间的数字:'
echo '你输入的数字为:'
read aNum
case $aNum in
1) echo '你选择了 1'
;;
2) echo '你选择了 2'
;;
3) echo '你选择了 3'
;;
4) echo '你选择了 4'
;;
*) echo '你没有输入 1 到 4 之间的数字'
;;
esac
1.6 跳出循环
1.6.1 break 命令
break命令允许跳出所有循环(终止执行后面的所有循环):
1.6.2 continue命令
continue命令与break命令类似,只有一点差别,它不会跳出所有循环,仅仅跳出当前循环。
二、函数
linux shell 可以用户定义函数,然后在shell脚本中可以随便调用。
shell中函数的定义格式如下:
[ function ] funname [()]
{
action;
[return int;]
}
:'
1、可以带function fun() 定义,也可以直接fun() 定义,不带任何参数。
2、参数返回,可以显示加:return 返回,如果不加,将以最后一条命令运行结果,作为返回值。 return后跟数值n(0-255)
'
三、输入/输出重定向
大多数 UNIX 系统命令从你的终端接受输入并将所产生的输出发送回到您的终端。一个命令通常从一个叫标准输入的地方读取输入,默认情况下,这恰好是你的终端。同样,一个命令通常将其输出写入到标准输出,默认情况下,这也是你的终端。
重定向命令列表如下:
命令 | 说明 |
---|---|
command > file | 将输出重定向到 file (ps:输出重定向会覆盖文件内容) |
command < file | 将输入重定向到 file,从file文件中读取内容,执行command。 |
command >> file | 将输出以追加的方式重定向到 file (ps:文件内容不会被覆盖,而是追加到文件末尾) |
n > file | 将文件描述符为 n 的文件重定向到 file。 |
n >> file | 将文件描述符为 n 的文件以追加的方式重定向到 file。 |
n >& m | 将输出文件 m 和 n 合并。 |
n <& m | 将输入文件 m 和 n 合并。 |
<< tag | 将开始标记 tag 和结束标记 tag 之间的内容作为输入。 |
输入重定向:
wc -l test.txt
输出:
2 test.txt
wc -l < test.txt
输出:
2
#注意:上面两个例子的结果不同:第一个例子,会输出文件名;第二个不会,因为它仅仅知道从标准输入读取内容。
command1 < infile > outfile
#同时替换输入和输出,执行command1,从文件infile读取内容,然后将输出写入到outfile中。
一般情况下,每个 Unix/Linux 命令运行时都会打开三个文件:
- 标准输入文件(stdin):stdin的文件描述符为0,Unix程序默认从stdin读取数据。
- 标准输出文件(stdout):stdout 的文件描述符为1,Unix程序默认向stdout输出数据。
- 标准错误文件(stderr):stderr的文件描述符为2,Unix程序会向stderr流中写入错误信息。
默认情况下,command > file 将 stdout 重定向到 file,command < file 将stdin 重定向到 file。
1.如果希望 stderr 重定向到 file,可以这样写:
command 2 > file #stderr 覆盖 file
command 2 >> file # stderr 追加到 file 文件末尾
2.如果希望将 stdout 和 stderr 合并后重定向到 file,可以这样写:(最常用)
command > file 2>&1
或
command >> file 2>&1
3.如果希望对 stdin 和 stdout 都重定向,可以这样写:
command < file1 >file2
#command 命令将 stdin 重定向到 file1,将 stdout 重定向到 file2。
4.如果希望执行某个命令,但又不希望在屏幕上显示输出结果,那么可以将输出重定向到 /dev/null:
command > /dev/null
如果希望屏蔽 stdout 和 stderr,可以这样写:
command > /dev/null 2>&1
:'
/dev/null 是一个特殊的文件,写入到它的内容都会被丢弃;
如果尝试从该文件读取内容,那么什么也读不到。
但是 /dev/null 文件非常有用,将命令的输出重定向到它,会起到"禁止输出"的效果。
'