注释
符号#!用来告诉系统它后面的参数是用来执行该文件的程序。在这个例子中我们使用/bin/sh来执行程序。(可以运行echo $SHELL来看你的系统是使用那一类shell, 比如ubuntu使用的是/bin/bash,则第一行写成#!/bin/bash)
当编辑好脚本时,如果要执行该脚本,还必须使其可执行。 要使脚本可执行: 编译 chmod +x filename这样才能用./filename来运行 .
美元符号的用法
运算符
解释
$0
shell的命令本身(包括完整路径)
1−9
数字表示shell 的第几个参数
$#
传递到脚本的参数个数
$*
以一个单字符串显示所有向脚本传递的参数
$!
后台运行的最后一个进程的ID号
@|与*相同
$-
显示shell使用的当前选项。
$?
显示最后命令的执行状况。0表示没有错误。
$$
脚本运行的ID号
变量
在shell编程中,所有的变量都由字符串组成,并且不需要对变量进行声明,例如:
```
temp="abc" #注意=前后不能有空格,否则变量值会被认为是一个命令
echo $temp; #变量在赋值时不需要加$符号,但是在调用时,需要加$符号。
echo {$temp}qwe;#当变量名与符号串连接在一起时,为了使其不被混淆,需要在变量周围加一对大括号。
```
管道,重定向和反短斜线
管道 (|) 将一个命令的输出作为另外一个命令的输入.
例如:
```
find -name"temp" |wc -l#即将find命令的输出作为wc命令输入,来统计当前目录下文件名包含temp的文件的个数
```
重定向:将命令的结果输出到文件,而不是标准输出(屏幕)
1. >写入文件并覆盖旧文件
2. >> 加到文件的尾部,保留旧文件内容。
3. /dev/null 代表空设备文件
> 代表重定向到哪里,例如:echo "123" > /home/123.txt
1 表示stdout标准输出,系统默认值是1,所以">/dev/null"等同于"1>/dev/null"
2 表示stderr标准错误
& 表示等同于的意思,2>&1,表示2的输出重定向等同于1
1>/dev/null 首先表示标准输出重定向到空设备文件,也就是不输出任何信息到终端,说白了就是不显示任何信息。
2>&1 接着,标准错误输出重定向等同于 标准输出,因为之前标准输出已经重定向到了空设备文件,所以标准错误输出也重定向到空设备文件。
反短斜线:使用反短斜线( ` )可以将一个命令的输出作为另外一个命令的一个命令行参数。
例如
ftype=`file "$1"` #将输入的第一个参数的文件信息赋值给ftype变量
流程控制
if
语法为: if ....; then
....
elif ....; then
....
else
....
fi #!/bin/sh
ftype=`file "$1"`
case "$ftype" in
"$1: Zip archive"*)
unzip "$1" ;;
"$1: gzip compressed"*)
gunzip "$1" ;;
"$1: bzip2 compressed"*)
bunzip2 "$1" ;;
*) echo "File $1 can not be uncompressed with smartzip";;
esac
selsect select var in ... ; do
break
done #!/bin/sh
echo "What is your favourite OS?"
select var in "Linux" "Gnu Hurd" "Free BSD" "Other"; do
break
done
echo "You have selected $var"
while while ...; do
....
done i=1
while(test $i -lt 20)
do
echo $i
done
for for var in ....; do
....
done #!/bin/sh
for var in A B C ; do
echo "var is $var"
done
引号
双引号防止通配符扩展
单引号防止通配符和变量扩展
使用转移字符也可以防止扩展
herdoc
comment string <<<
body
string;
注意
以 <<
位于开始标记和结束标记之间的变量可以被正常解析,但是函数则不可以。
heredoc常用在输出包含大量HTML语法d文档的时候。比如:函数outputhtml()要输出HTML的主页。可以有两种写法。很明显第二种写法比较简单和易于阅读。