特殊的shell变量
| 变量 | 含义 |
| $0 |
脚本名 |
| $1 -$9 |
位置参数1-9 |
| ${10} |
位置参数10 |
| $# |
位置参数的个数 |
| "$*" |
所有位置参数(作为单个字符串) |
| "$@" |
所有位置参数(每个作为单独字符串) |
| ${#*} |
传递到脚本中的命令行参数的个数 |
| ${#*} |
传递到脚本中的命令行参数的个数 |
| $? |
返回值 |
| $$ |
脚本进程的PID |
| $- |
传递到脚本中的标识 |
| $_ |
之前命令的最后一个参数 |
| $! |
运行在后台的最后一个作业的进程ID(PID) |
测试操作: 二元比较
算 术比较
| 操作符 | 含义 |
| -eq |
等于 |
| -ne |
不等于 |
| -lt或((<)) |
小于 |
| -le或((<=)) |
小于等于 |
| -gt 或((>)) |
大于 |
| -ge |
大于等于 |
字符串比较
| 操作符 | 含义 |
| = |
|
| == |
|
| != |
|
| < |
小于(ASCII) |
| > |
大于(ASCII) |
| -z |
字符串为空 |
| -n |
字符串不为空 |
果在双中括号 [[ ... ]] 测试结构中使用的话, 那么就不需要使用转义符了.
文件类型操作
| 操作符 | 含义 |
| -e |
文件是否 |
| -f |
标准文件 |
| -d |
目录 |
| -h |
hard link链接 |
| -L |
link |
| -b |
块设备 |
| -c |
字符设备 |
| -p |
管道 |
| -S |
socket套接字 |
| -t |
文件与终端相关联 |
| -N |
文件最后一次读取后被修改过 |
| -O |
文件属主是自己 |
| -G |
组id与执行者一致 |
| -s |
文件大小不为0 |
| -r |
文件具有读权限 |
| -w |
文件具有写权限 |
| -x |
文件具有执行权限 |
| -g |
设置了sgid标记 |
| -u |
设置了suid标记 |
| -k |
设置了黏贴位 |
| file1 -nt file2 |
file1比文件file2新 |
| file1 -ot file2 |
file1比file2旧 |
| file1 -ef file2 |
fiel1和fiel2是同一个文件的硬链接 |
参数替换和扩展
| 表达式 | 含义 |
| ${var_DEFAULT} |
如果var没 有被声明, 那么就以$DEFAULT作为其值 * |
| ${var=DEFAULT} |
如果var没 有被声明, 那么就以$DEFAULT作为其值 * |
| ${var:-DEFAULT} |
如果var没 有被声明, 或者其值为空, 那么就以$DEFAULT作为其值 * |
| ${var:=DEFAULT} |
如果var没 有被声明, 或者其值为空, 那么就以$DEFAULT作为其值 * |
| ${var+OTHER} |
如果var声 明了, 那么其值就是$OTHER, 否则就为null字符串 |
| ${var:+OTHER} |
如 果var被设置了, 那么其值就是$OTHER, 否则就为null字符串 |
| ${var?ERR_MSG} |
如果var没 被声明, 那么就打印$ERR_MSG* |
| ${var:?ERR_MSG} |
如果var没 被设置, 那么就打印$ERR_MSG* |
| ${!varprefix*} |
匹配之前所有以varprefix开头进行声明的变量 |
| ${!varprefix@} |
匹配之前所有以varprefix开头进行声明的变量 |
字符串操作
| 表达式 | 含义 |
${#string} |
$string的 长度 |
${string:position} |
在$string中, 从位置$position开始提取子串 |
${string:position:length} |
在$string中, 从位置$position开始提取长度为$length的子串 |
${string#substring} |
从 变量$string的开头, 删除最短匹配$substring的子串 |
${string##substring} |
从 变量$string的开头, 删除最长匹配$substring的子串 |
${string%substring} |
从 变量$string的结尾, 删除最短匹配$substring的子串 |
${string%%substring} |
从 变量$string的结尾, 删除最长匹配$substring的子串 |
${string/substring/replacement} |
使用$replacement, 来代替第一个匹配的$substring |
${string//substring/replacement} |
使 用$replacement, 代替所有匹配的$substring |
${string/#substring/replacement} |
如 果$string的前缀匹配$substring, 那么就用$replacement来代替匹配到的$substring |
${string/%substring/replacement} |
如果$string的后缀匹配$substring, 那么就用$replacement来代替匹配到的$substring |
expr match "$string" '$substring' |
匹配$string开头的$substring* 的长度 |
expr "$string" : '$substring' |
匹 配$string开头的$substring* 的长度 |
expr index "$string" $substring |
在$string中匹配到的$substring的第一个字符出现的位置 |
expr substr $string $position $length |
在$string中 从位置$position开始提取长度为$length的子串 |
expr match "$string" '($substring)' |
从$string的 开头位置提取$substring* |
expr "$string" : '($substring)' |
从$string的 开头位置提取$substring* |
expr match "$string" '.*($substring)' |
从$string的 结尾提取$substring* |
expr "$string" : '.*($substring)' |
从$string的 结尾提取$substring* |
$substring是一个正 则表达式.
一些结构的汇总
| 表达式 | 含义 |
| if [ CONDITION ] |
测 试结构 |
| if [[ CONDITION ]] |
扩 展的测试结构 |
| Array[1]=element1 |
数 组初始化 |
| [a-z] |
正 则表达式的字符范围 |
| ${!variable} |
间 接变量引用 |
| { command1; command2; . . . commandN; } |
代码块 |
| {string1,string2,string3,...} |
大 括号扩展 |
| ( command1; command2 ) |
子shell中 执行的命令组 |
| Array=(element1 element2 element3) |
数组初始化 |
| result=$(COMMAND) |
在 子shell中执行命令, 并将结果赋值给变量 |
| >(COMMAND) |
进程替换 |
| <(COMMAND) |
进 程替换 |
| (( var = 78 )) |
整型运算 |
| var=$(( 20 + 5 )) |
整型运算, 并将结果赋值给变量 |
| "$variable" |
|
result=COMMAND |
在 子shell中运行命令, 并将结果赋值给变量 |
参考http://blog.csdn.net/u012749933/article/details/48030503