zoukankan      html  css  js  c++  java
  • 命令__shell数字-字符串比较


    shell常用逻辑判断
    -b file 若文件存在且是一个块特殊文件,则为真
    -c file 若文件存在且是一个字符特殊文件,则为真
    -d file 若文件存在且是一个目录,则为真
    -e file 若文件存在,则为真
    -f file 若文件存在且是一个规则文件,则为真
    -g file 若文件存在且设置了SGID位的值,则为真
    -h file 若文件存在且为一个符合链接,则为真
    -k file 若文件存在且设置了"sticky"位的值
    -p file 若文件存在且为一已命名管道,则为真
    -r file 若文件存在且可读,则为真
    -s file 若文件存在且其大小大于零,则为真
    -u file 若文件存在且设置了SUID位,则为真
    -w file 若文件存在且可写,则为真
    -x file 若文件存在且可执行,则为真
    -o file 若文件存在且被有效用户ID所拥有,则为真

    -z string 若string长度为0,则为真
    -n string 若string长度不为0,则为真
    string1 = string2 若两个字符串相等,则为真
    string1 != string2 若两个字符串不相等,则为真

    int1 -eq int2 若int1等于int2,则为真
    int1 -ne int2 若int1不等于int2,则为真
    int1 -lt int2 若int1小于int2,则为真
    int1 -le int2 若int1小于等于int2,则为真
    int1 -gt int2 若int1大于int2,则为真
    int1 -ge int2 若int1大于等于int2,则为真

    !expr 若expr为假则复合表达式为真。expr可以是任何有效的测试表达式
    expr1 -a expr2 若expr1和expr2都为真则整式为真
    expr1 -o expr2 若expr1和expr2有一个为真则整式为真

    特殊变量:
    $0 正在被执行命令的名字。对于shell脚本而言,这是被激活命令的路径
    $n 该变量与脚本被激活时所带的参数相对应。n是正整数,与参数位置相对应($1,$2…)
    $# 提供脚本的参数号
    $* 所有这些参数都被双引号引住。若一个脚本接收两个参数,$*等于$1$2
    $@ 所有这些参数都分别被双引号引住。若一个脚本接收到两个参数,$@等价于$1$2
    $? 前一个命令执行后的退出状态
    $$ 当前shell的进程号。对于shell脚本,这是其正在执行时的进程ID
    $! 前一个后台命令的进程号

    其中下面两种判断:
    expr1 -a expr2 若expr1和expr2都为真则整式为真
    expr1 -o expr2 若expr1和expr2有一个为真则整式为真

    本人亲测过不行,不知道是不是格式出了问题,待解答

    例子:
    if [ ! -z $err -o ! -e $apk ]; then 会报出-e无法找到的错误;
    而if [ ! -z $err ] || [ ! -e $apk ]; then 没问题;


    整数比较 :
    -eq 等于,如:if [ "$a" -eq "$b" ]
    -ne 不等于,如:if [ "$a" -ne "$b" ]
    -gt 大于,如:if [ "$a" -gt "$b" ]
    -ge 大于等于,如:if [ "$a" -ge "$b" ]
    -lt 小于,如:if [ "$a" -lt "$b" ]
    -le 小于等于,如:if [ "$a" -le "$b" ]
    < 小于(需要双括号),如:(("$a" < "$b"))
    <= 小于等于(需要双括号),如:(("$a" <= "$b"))
    > 大于(需要双括号),如:(("$a" > "$b"))
    >= 大于等于(需要双括号),如:(("$a" >= "$b"))


    字符串比较 :
    = 等于,如:if [ "$a" = "$b" ]
    == 等于,如:if [ "$a" == "$b" ],与=等价
    注意:==的功能在[[]]和[]中的行为是不同的,如下:
    [[ $a == z* ]] # 如果$a以"z"开头(模式匹配)那么将为true
    [[ $a == "z*" ]] # 如果$a等于z*(字符匹配),那么结果为true

    [ $a == z* ] # File globbing 和word splitting将会发生
    [ "$a" == "z*" ] # 如果$a等于z*(字符匹配),那么结果为true
    #一点解释,关于File globbing是一种关于文件的速记法,比如"*.c"就是,再如~也是. 但是file globbing并不是严格的正则表达式,虽然绝大多数情况下结构比较像.

    != 不等于,如:if [ "$a" != "$b" ] ;这个操作符将在[[]]结构中使用模式匹配.

    < 小于,在ASCII字母顺序下.如:
    if [[ "$a" < "$b" ]]
    if [ "$a" < "$b" ]
    注意:在[]结构中"<"需要被转义.

    > 大于,在ASCII字母顺序下.如:
    if [[ "$a" > "$b" ]]
    if [ "$a" > "$b" ]
    注意:在[]结构中">"需要被转义.

    -z 字符串为"null".就是长度为0.
    -n 字符串不为"null"
    注意:
    使用-n在[]结构中测试必须要用""把变量引起来.使用一个未被""的字符串来使用! -z 或者就是未用""引用的字符串本身,放到[]结构中。虽然一般情况下可 以工作,但这是不安全的.习惯于使用""来测试字符串是一种好习惯.
    awk '{print $2}' class.txt | grep '^[0-9.]' > res




    SHELL下的数字比较及计算

    比较:
    方法一: if [ ${A} -lt ${B} ]; then ...
    这是最基本的比较方法,使用lt(小于),gt(大于),le(小于等于),ge(大于等于),优点:还没发现;缺点:只能比较整数,使用lt,gt等不直观 ;
    方法二: if ((${A} < ${B})) then ...
    这是CShell风格比较,优点:不用使用lt,gt等难记的字符串;缺点:还是只能比较整数
    方法三: if (echo ${A} ${B} | awk '!($1>$2){exit 1}') then ...
    这是使用awk比较,优点:可以比较小数;缺点:表达式太复杂,难记
    方法四: if (echo ${A} - ${B} | bc -q | grep -q "^-"); then ...
    这是使用bc计算比较,优点:可以比较小数;缺点:表达式更复杂,难记

    计算:
    方法一:typeset C=$(expr ${A} + ${B});
    SHELL中的基本工具,优点:方便检测变量是否为数字;缺点:只能计算整数,且只能计算加减法,不能计算乘除法
    方法二:let "C=${A}+${B}"; 或 let "C=A+B"
    内嵌命令计算,优点:能计算乘除法及位运算等;缺点:只能计算整数
    方法三:typeset C=$((A+B))
    CShell风格的计算,优点:能计算乘除法及位运算等,简介,编写方便;缺点:不能计算小数
    方法四:typeset C=${echo ${A} ${B} | awk '{print $1+$2}')
    使用awk计算,优点:能计算小数,可以实现多种计算方式,计算灵活;缺点:表达式太复杂
    方法五:typeset C=${echo ${A} + ${B} | bc -q)
    使用awk计算,优点:能计算小数,计算方式比awk还多,计算灵活;
    缺点:表达式太复杂,小数点后面的位数必须使用scale=N来设置,否则可能会将结果截断为整数


    特殊字符 :
    符号 使用
    ; 一般情况我们输出完一个命令需要按一个回车,如果你想在一行执行多个命令,中间可以用;号分割 cd /home ; ls
    * 表示任意字符(正则)
    ? 任一个字符
    [abc] 列表项之一
    [^abc] 对于列表取非 也可以使用范围 [a-z] [0-9] [A-Z](所有字符和数字)
    {} 循环列表时用 touch_{1,2,3}时就会建立touch_1,touch_2,touch_3循环出这三个文件,也会用 echo ${ab}c
    ~ home目录cd ~ (普通通话进入的是/home目录下用户自己的家目录)
    $ 提取变量值
    `` $() 命令替换touch `date +%F_\`date +%T\`` touch $(date +%F_$(date +%T))
    $[] 整数计算 echo $[2+3] - * / % 浮点数用 echo "scale=3; 10/3" | bc -l (bc用于计算的)
    转义后面的字符串 echo \ 输出 转义特殊字符,为防止被SHELL解释bash中的特殊字符
    "" '' 带空格串 将空格视为串的一部分 echo "abc xyz" echo 'abc xyz'
    `` 命令替换 取命令的执行结果
    $() 同上,但它弥补了``的嵌套缺陷
    @ 无特殊含义
    # 注释(一般编程都需要加注释,让其他团队队员对自己写的程序功能了解)
    $ 变量取值
    $() 命令替换
    ${} 变量名的范围
    % 杀后台经常jobs号,取模运算(大家对取模应该并不陌生)
    ^ 取非 和 !雷同
    & 用进程后台处理, &&用于逻辑与
    * 匹配任意字符串;计算乘法
    () 子进程执行
    - 减号,区间,cd - 回到上层目录,杀掉当前jobs

    _ (下划线)无特殊含义
    + 加号; 杀掉当前jobs(进程)
    = 赋值
    | 管道,|| 逻辑或
    转义 当一些特殊符号如$是一个变量需要转义才不被bash解析
    {} 命令列表 {ls;cd /;}
    [] 字符通配符,[]也是用于测试命令
    : 空命令 真值
    ; 命令结束符
    "" 软引 '' 硬引
    < 输入重定向
    > 输出重定向
    >& 合并2和1输出
    , 枚举分隔符
    . 当前目录
    / 目录分隔符
    ? 单个字符
    回车 命令执行


    详细出处参考:http://www.jb51.net/article/37809.htm

  • 相关阅读:
    Spring MVC的Controller统一异常处理:HandlerExceptionResolver
    Log4j按级别输出日志到不同文件配置
    Linux top命令用法
    free -m内存使用详解
    Linux运维中遇到的常见问题
    ubuntu16.04 nginx安装
    redis主从配置及主从切换
    Redis持久化配置-AOF
    如何处理消极想法
    libevent安装总结
  • 原文地址:https://www.cnblogs.com/sun-frederick/p/4763528.html
Copyright © 2011-2022 走看看