• shell中的参数扩展, 特殊变量


    echo $SHLVL  该变量包含当前工作的shell level

    $*  所有参数列表 受IFS控制

    PS1 为提示符,可进行设置 PS1="[\u@\h \W]\$"
    PS2 为换行时的那个符号如 aa '换行后默认会出现>我们可以进行修改 PS2=''换成你喜欢的
    IFS 为变量的分隔符,默认是空格

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

    变量含义
    $0 shellshell脚本的名字
    $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中运行命令, 并将结果赋值给变量

    可以这样理解一下:-(减号)就是变量不存在(被减掉的意思)时, 返回缺省值

                                 +(加号)就是变量存在(加号代表正, 正就是存在的意思)时, 返回缺省值

                                 =(等号,赋值号)和减号(-)的效果类似, 只是影响到了旧的变量

  • 相关阅读:
    svn使用
    navicat 15 安装破解
    thinkpad交换Fn和Ctrl
    emqx_mqtt安装+mqtt管理工具
    Adobe XD使用
    FolderPainter:windows系统为文件夹设置不同颜色
    rest client 代替postman
    使用bfg快速清理git历史大文件
    Adobe Acrobat XI Pro v11.0.10中文版
    Excel 2016打开文档时提示“操作系统当前的配置不能运行此应用程序”
  • 原文地址:https://www.cnblogs.com/xkfz007/p/2336318.html
Copyright © 2020-2023  润新知