文档库 最新最全的文档下载
当前位置:文档库 › shell编程参考

shell编程参考

参考卡片

表格B-1. 特殊的shell变量

变量含义

$0 脚本名字

$1 位置参数#1

$2 - $9 位置参数#2 - #9

${10} 位置参数#10

$# 位置参数的个数

"$*" 所有的位置参数(作为单个字符串) *

"$@" 所有的位置参数(每个都作为独立的字符串)

${#*} 传递到脚本中的命令行参数的个数

${#@} 传递到脚本中的命令行参数的个数

$? 返回值

$$ 脚本的进程ID(PID)

$- 传递到脚本中的标志(使用set)

$_ 之前命令的最后一个参数

$! 运行在后台的最后一个作业的进程ID(PID)

*必须被引用起来, 否则默认为"$@".

表格B-2. 测试操作: 二元比较

操作描述----- 操作描述

算术比较字符串比较

-eq 等于= 等于

== 等于

-ne 不等于!= 不等于

-lt 小于\< 小于(ASCII) *

-le 小于等于

-gt 大于\> 大于(ASCII) *

-ge 大于等于

-z 字符串为空

-n 字符串不为空

算术比较双括号(( ... ))结构

> 大于

>= 大于等于

< 小于

<= 小于等于

*如果在双中括号[[ ... ]] 测试结构中使用的话, 那么就不需要使用转义符\了.

表格B-3. 文件类型的测试操作

操作测试条件

---

--

操作测试条件

-e 文件是否存在-s 文件大小不为0 -f 是一个标准文件

-d 是一个目录-r 文件具有读权限-h 文件是一个符号链接-w 文件具有写权限-L 文件是一个符号链接-x 文件具有执行权限-b 文件是一个块设备

-c 文件是一个字符设备-g 设置了sgid标记-p 文件是一个管道-u 设置了suid标记-S 文件是一个socket-k 设置了"粘贴位" -t 文件与一个终端相关联

-N 从这个文件最后一次被读取之后, 它

被修改过

F1 -nt

F2

文件F1比文件F2新*

-O 这个文件的宿主是你F1 -ot

F2

文件F1比文件F2旧*

-G 文件的组id与你所属的组相同F1 -ef

F2

文件F1和文件F2都是同一个文件

的硬链接*

! "非"(反转上边的测试结果)

*二元操作符(需要两个操作数).

表格B-4. 参数替换和扩展

表达式含义

${var} 变量var的值, 与$var相同

${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开头进行声明的变量

*当然, 如果变量var已经被设置的话, 那么其值就是$var.

表格B-5. 字符串操作

表达式含义

${#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是一个正则表达式.

表格B-6. 一些结构的汇总

表达式解释

中括号

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中运行命令, 并将结果赋值给变量

相关文档