本文也即《Learning the bash Shell》3rd Edition的第五章Flow Control之读书笔记,但我们将不限于此。flow control是任何编程语言中很常用的部分,也包括了bash。在这里,我们将学习他们。

  if/else是通过判断选择执行或者执行部分代码,可以根据变量、文件名、命令是否执行成功等很多条件进行判断,他的格式如下:

if condition

then

statements

[elif

condition

then

statements.

..]

[else

statements

]

fi

  和 C程序不一样,bash的判断不是通过boolean,而是通过statement,也就是执行命令后的最终状态(exit
status)。所有的Linux命令,无论你是代码是C还是脚本,执行完,都返回一个整数通知他的调用这,这就是exit
status,通常0表示OK,其他(1-255)表示错误。这只是通常的情况,例如diff,0表示你no
difference,1表示difference,2表示错误。if判断statements的最后一个的exit
status,通常我们只放一个statement,如果为0,表示true,否则表示false。

  执行下一条命令会冲掉原来exit
status。可以使用$?来查看上一命令执行的结果。例如我们希望用一个新的cd命令来替代原来在linux
kernel中已将编译的cd命令,由于function是优先于built-in命令,所以调用时,将调用我们的function。下面有一个例
子,function pushd,在stack中键入cd的dirname路径名,并执行跳到该路径下。

cd ( )

{

#由于我们已经定义了具有更高优先级别的function,如果希望调用原来built-in的命令,需要再前面加上builtin。

builtin

cd "$@"

#$?是上一command的返回值,即builtin cd "$@"的值,并记录在result里面。

result=$?

echo "$OLDPWD --> $PWD"

#返回result的值。我们需要注意shell中的返回和在其他程序,例如C语
言中的返回是不一样的,只代表最后的exit
statue,而不是所谓的返回值,虽然也用到了return。如何没有最后的reture,例如后面的push_func,exit
status就是最后执行的command的exit status

return

$result

}

push_func( )

{

dirname=$1

#如果dirname为null,退出funcuntion,如cd dirname成功,push the directory ,否则显示still in $PWD,cd使用function的cd函数,其优先级别高于已在内核编译了的cd

if

cd ${dirname:?"missing directory name."}

then

mystack="$dirname ${mystack:-$OLDPWD }"

echo $mystack

else

echo still in $PWD.

fi

}

push_func $1

条件结合

  和C语言一样,可以进行条件结合,使用&&,||,以及!三种方式,表示“和”,“或”,与”非“,格式如下:if statement1

&&

statement2,

if statement1

||

statement2

,if

statement1

  exit status不是判断的唯一值,可以使用[...]和[[...]]。

字符串比较

  字符串比较是放置在[...]中,有以下的几种:

  • str1 = str2,字符串1匹配字符串2
  • str1 != str2,字符串1不匹配字符串2
  • str1 > str2,字符串1大于字符串2
  • str1 < str2,字符串1小于字符串2
  • -n str,字符串不为null,长度大于零
  • -z str,字符串为null,长度为零

  需要注意<和>符号和重定向符号相似,为了避免歧义和错误,使用if [ $a

/>

$b

] 的方式

。仍然上面的例子,我们增加pop_func来操作stack:

pop_func()

{

mystack=${mystack#* }

#下面请至于[ ... ],即[后面有一个空格,]前面有一空格,另外$mystack用双引号,表示这代表的是一个字符串。注意到then不放在下一行,与if放在用一行,用;来隔开。

if [ -n "$mystack" ];

then

cd ${mystack%% *}

echo "$PWD", stack is [$mystack]

else

echo "stack empty, still in $PWD."

fi

}

  例如,我们要求命令带有参数,除了使用{1?"<message"}以外,下面给出更可读的方式:

if [ -z "$1" ]; then

echo 'usage: c filename [-N]'

exit

1

fi

  在这里exit表示结束,退出,执行的结果为失败,非零。

文件属性比较

  文件属性比较是另一个常用的条件判断类型。

  • -a

    file

    :file 存在

  • -d

    file

    :file存在并是一个目录

  • -e

    file

    :file 存在,同- a

  • -f

    file

    :file 存在并且是一个常规的文件(不是目录或者其他特殊类型文件)

  • -r

    file

    :有读的权限

  • -s

    file

    :文件存在且不为空

  • -w

    file

    :有写的权限

  • -x

    file

    :有执行的权限,或者对于目录有search的权限

  • -N

    file

    :在上次读取后,文件有改动

  • -O

    file

    :own所属的文件

  • -G

    file

    :group所属的文件

  • file1

    -nt

    file2

    :file1 比 file2 更新,以最后更新时间为准

  • file1

    -ot

    file2

    :file1 比 file2 更旧 ,以最后更新时间为准

  这些在[ ... ]中的条件判断是可以多个结合起来,例如if [ condition ] && [
condition ]; then,当然也可以if command && [ condition ];
then,不在类推。尤其我们可以进行复制的条件判断。另外还可以使用-a

-o

,等同于C语言中的&和|的逻辑计算复符号,他们和&&即||相似。当他们用在condition里面。

  在上面push_func的例子中,除了判断是否参数之外,增加判断是否是目录名,如下:

if [ -n "$dirname" ] &&[ -d "$dirname" ]

then

cd $dirname

mystack="$dirname ${mystack:-$OLDPWD }"

echo $mystack

else

echo still in $PWD.

fi

  我们在增加一个判断,当时目录名的时候,在检查是否可以进行查看或操作。使用if [ -n "$dirname" ] &&[ -d "$dirname" -a -x "$dirname"

],但是这种写法很难阅读,我们需要将两个前后判断括起来,( -d "$dirname" ) -a ( -x "$dirname" )。但是(是个特殊符合,需使用/(的方式,即为:if [ -n "$dirname" ] &&[ /( -d "$dirname" /) -a /( -x "$dirname" /) ]

整数比较

  >或者<或者=是用于字符串的比较,如果用于整数比较,使用:

  • -lt,小于
  • -le,小于等于
  • -eq,等于
  • -ge,大于等于
  • -gt,大于
  • -ne,不等于

[shell] if else以及大于、小于、等于逻辑表达式 [转]的更多相关文章

  1. shell的if else 以及大于,小于等逻辑表达式

    if ....; then .... elif ....; then .... else .... fi 大多数情况下,可以使用测试命令来对条件进行测试.比如可以比较字符串.判断文件是否存在及是否可读 ...

  2. oracle中时间格式时候的大于号是大于和等于的意思

    oracle中时间格式时候的大于号是大于和等于的意思

  3. Mybatis在xml配置文件中处理SQL中的大于小于号的方法

    之前在项目中遇到了在SQL中<=不识别的问题,在Navicat中语句正常,在xml中不识别,想起来就记录一下 项目用的是Mybatis,经过网上多次查询,验证,总结方法如下: 一.使用<! ...

  4. shell中 if else以及大于、小于、等于逻辑表达式介绍

    比如比较字符串.判断文件是否存在及是否可读等,通常用"[]"来表示条件测试. 注意:这里的空格很重要.要确保方括号的空格.笔者就曾因为空格缺少或位置不对,而浪费好多宝贵的时间. i ...

  5. linux shell中 if else for循环以及大于、小于、等于逻辑表达式的历程

    作者:邓聪聪 比如比较字符串.判断文件是否存在及是否可读等,通常用"[]"来表示条件测试. 注意:这里的空格很重要.要确保方括号的空格.笔者就曾因为空格缺少或位置不对,而浪费好多宝 ...

  6. linux shell中 if else以及大于、小于、等于逻辑表达式

    在linux shell编程中,大多数情况下,可以使用测试命令来对条件进行测试,这里简单的介绍下,方便需要的朋友 比如比较字符串.判断文件是否存在及是否可读等,通常用"[]"来表示 ...

  7. linux shell中 if else以及大于、小于、等于逻辑表达式介绍

    在linux shell编程中,大多数情况下,可以使用测试命令来对条件进行测试,这里简单的介绍下, 比如比较字符串.判断文件是否存在及是否可读等,通常用"[]"来表示条件测试. 注 ...

  8. if else以及大于、小于、等于逻辑表达式

    大多数情况下,可以使用测试命令来对条件进行测试.比如可以比较字符串.判断文件是否存在及是否可读等,通常用"[]"来表示条件测试.注意这里的空格很重要.要确保方括号的空格. if . ...

  9. 动态LINQ构建(实现等于不等于大于小于,like以及IN)

    首先感谢园子里的“红烧狮子头”,他的工作是本文的基础,引文如下http://www.cnblogs.com/daviddai/archive/2013/03/09/2952087.html,本版本实现 ...

随机推荐

  1. python动态获取对象的属性和方法

    http://blog.csdn.net/kenkywu/article/details/6822220首先通过一个例子来看一下本文中可能用到的对象和相关概念.01     #coding: UTF- ...

  2. 【转】如何用 Chrome for Android 做远程遥控 debugging

    http://blog.csdn.net/wuchengzhi82/article/details/22190435

  3. HDU 1848 Fibonacci again and again (斐波那契博弈SG函数)

    Fibonacci again and again Time Limit: 1000MS   Memory Limit: 32768KB   64bit IO Format: %I64d & ...

  4. HDU 4310 Hero (贪心算法)

    A - Hero Time Limit:3000MS     Memory Limit:65536KB     64bit IO Format:%I64d & %I64u Submit Sta ...

  5. 组合数(codevs 1631)

    1631 组合数  时间限制: 1 s  空间限制: 256000 KB  题目等级 : 钻石 Diamond 题解  查看运行结果     题目描述 Description 组合数C(N, K)表示 ...

  6. 好玩儿的expect

    前言 1> 借鉴里面的应用思想,使用断言提高代码的健壮性及维护性 2> 实现方式——不采用直接嵌入expect的方式,统一进行重写(提取常用断言方法,重新构造API) 官网介绍 https ...

  7. android 输入法出现挤压屏幕、android输入键盘覆盖了屏幕控件的解决办法

    如果希望输入法键盘弹出时不自动向上挤压activity,在Manifest清单文件中对应的activty中设置属性android:windowSoftInputMode="adjustPan ...

  8. Android数据存储之sharedpreferences与Content Provider

    android中对数据操作包含有: file, sqlite3, Preferences, ContectResolver与ContentProvider前三种数据操作方式都只是针对本应用内数据,程序 ...

  9. rsync --exclude 参数

    /usr/bin/rsync -vr --exclude=".svn" --exclude="temp" --delete /alidata/www/pro/e ...

  10. js prototype

    1 原型法设计模式 在.Net中可以使用clone()来实现原型法 原型法的主要思想是,现在有1个类A,我想要创建一个类B,这个类是以A为原型的,并且能进行扩展.我们称B的原型为A. 2 javasc ...