您的位置:首页 > 运维架构 > Linux

linux shell bash 内置变量参考

2017-06-07 22:50 381 查看
  • [ul] 特殊的shell变量
  • 测试操作: 二元比较 算 术比较
  • 字符串比较
  • 文件类型操作
  • 参数替换和扩展
  • 字符串操作
  • 一些结构的汇总
  • [/ul]

     

    特殊的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

    内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
    标签: