Shell卡片

Shell卡片

第一节:特殊的shell变量

变量 含义
$0 脚本名字
$1 位置参数 #1
$2 - $9 位置参数 #2 - #9
${10} 位置参数 #10
$# 位置参数的个数
"$*" 所有的位置参数(作为单个字符串) *
"$@" 所有的位置参数(每个都作为独立的字符串)
${#*} 传递到脚本中的命令行参数的个数
${#@} 传递到脚本中的命令行参数的个数
$? 返回值
$$ 脚本的进程ID(PID)
$- 传递到脚本中的标志(使用set)
$_ 之前命令的最后一个参数
$! 行在后台的最后一个作业的进程ID(PID)

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

第二节:测试操作: 二元比较

操作 描述 操作 描述
算术比较 字符串比较
-eq 等于 = 等于
== 等于
-ne 不等于 != 不等于
-lt 小于 \< 小于(ASCII)*
-le 小于等于
-gt 大于 > 大于(ASCII)*
-z 字符串为空
-n 字符串不为空
算术比较 双括号((.))结构
> 大于
>= 大于等于
< 小于
<= 小于等于

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

第三节:文件类型的测试操作

操作 测试条件 操作 测试条件
-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都是同一个文件的硬链接 *
! “非” (反转上边的测试结果)

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

第四节:参数替换和扩展

表达式 含义
${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.

第五节:字符串操作

表达式 含义
${#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中从位置 p o s i t i o n 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;} 代码块
{string1,string2,} 大括号扩展
圆括号
(command1; command2) 子shell中执行的命令组
Array=(element1 element2 element3) 数组初始化
result=$(COMMAND) 在子shell中执行命令, 并将结果赋值给变量
>(COMMAND) 进程替换
<(COMMAND) 进程替换
双圆括号
(( var = 78 )) 整型运算
var=$(( 20 + 5 )) 整型运算, 并将结果赋值给变量
引号
"$variable" “弱”引用
‘string’ “强”引用
后置引用
result=COMMAND 在子shell中运行命令, 并将结果赋值给变量

第七节:(等待补充)

猜你喜欢

转载自blog.csdn.net/caodenghua/article/details/80068894