Linux shell bash内置变量参考

  1. 特殊的shell变量
  • 测试操作:二元比较
    1. 算术比较
    2. 字符串比较
    3. 文件类型操作
    4. 参数替换和扩展
    5. 字符串操作
    6. 一些结构的汇总
  • 特殊的shell变量

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

    测试操作:二元比较

    算术比较

    操作符含义
    -eq等于
    -ne不等于
    -lt 或 ((<))小于
    -le 或 ((<=))小于等于
    -gt 或 ((>))大于
    -ge大于等于
    双括号(( … ))结构
    >大于
    >=大于等于
    <小于
    <=小于等于

    字符串比较

    操作符含义
    =等于
    ==等于
    !=不等于(这个操作符将在[[]]结构中使用模式匹配)
    <小于(ASCII)
    >大于(ASCII)
    -z字符串为空
    -n字符串不为空

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

    注意:

    ==的功能在[[]]和[]中的行为是不同的,如下:

    1. [[ $a == z* ]] # 如果$a以”z”开头(模式匹配)那么将为true

    2. [[ $a == “z*” ]] # 如果$a等于z*(字符匹配),那么结果为true

    3. [ “$a” == “z*” ] # 如果$a等于z*(字符匹配),那么结果为true

    4. [ $a == z* ] # File globbing 和word splitting将会发生

    文件类型操作

    操作符含义
    -e文件是否
    -f标准文件
    -d目录
    -hhard link链接
    -Llink
    -b块设备
    -c字符设备
    -p管道
    -Ssocket套接字
    -t文件与终端相关联
    -N文件最后一次读取后被修改过
    -O文件属主是自己
    -G组id与执行者一致
    -s文件大小不为0
    -r文件具有读权限
    -w文件具有写权限
    -x文件具有执行权限
    -g设置了sgid标记
    -u设置了suid标记
    -k设置了黏贴位
    file1 -nt file2file1比文件file2新
    file1 -ot file2file1比file2旧
    file1 -ef file2file1和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中运行命令, 并将结果赋值给变量

    转载请注明来源