特殊的shell变量
| 变量 | 含义 |
|---|---|
| $0 | 脚本名 |
| $1 -$9 | 位置参数1-9 |
| ${10} | 位置参数10 |
| $# | 位置参数的个数 |
| “$*” | 所有位置参数(作为单个字符串) |
| “$@” | 所有位置参数(每个作为单独字符串) |
| ${#*} | 传递到脚本中的命令行参数的个数 |
| $? | 返回值 |
| $$ | 脚本进程的PID |
| $- | 传递到脚本中的标识 |
| $_ | 之前命令的最后一个参数 |
| $! | 运行在后台的最后一个作业的进程ID(PID) |
测试操作:二元比较
算术比较
| 操作符 | 含义 |
|---|---|
| -eq | 等于 |
| -ne | 不等于 |
| -lt 或 ((<)) | 小于 |
| -le 或 ((<=)) | 小于等于 |
| -gt 或 ((>)) | 大于 |
| -ge | 大于等于 |
| 双括号(( … ))结构 | |
| > | 大于 |
| >= | 大于等于 |
| < | 小于 |
| <= | 小于等于 |
字符串比较
| 操作符 | 含义 |
|---|---|
| = | 等于 |
| == | 等于 |
| != | 不等于(这个操作符将在[[]]结构中使用模式匹配) |
| < | 小于(ASCII) |
| > | 大于(ASCII) |
| -z | 字符串为空 |
| -n | 字符串不为空 |
如果在双中括号 [[ … ]] 测试结构中使用的话, 那么就不需要使用转义符\了
注意:
==的功能在[[]]和[]中的行为是不同的,如下:
[[ $a == z* ]] # 如果$a以”z”开头(模式匹配)那么将为true
[[ $a == “z*” ]] # 如果$a等于z*(字符匹配),那么结果为true
[ “$a” == “z*” ] # 如果$a等于z*(字符匹配),那么结果为true
[ $a == z* ] # File globbing 和word splitting将会发生
文件类型操作
| 操作符 | 含义 |
|---|---|
| -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 | file1和file2是同一个文件的硬链接 |
注:以上操作符加上”!”表示”非” (反转上边的测试结果)
参数替换和扩展
| 表达式 | 含义 |
|---|---|
| ${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} | 参数替换 |
| ${!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” | “弱”引用 |
| ‘string’ | “强”引用 |
| 后置引用 | |
| result=COMMAND | 在子shell中运行命令, 并将结果赋值给变量 |
转载请注明来源