格式

“#”代表空格,不可缺少

  • [# param1#op# param2 #]

这种带比较操作符的形式,op左右必须使用空格隔开.

如 [# “3”==”2” #]  这种缺少空格的写法会得到结果“true”,当然实际应为”false”.

  • 变量的引用应使用双引号括起来 [# -z “$name” #].

*********************

name="Jim"

[ $name == "Jack" ]   #将会变成 [ Jim == "Jack" ], 也就出现错误了.

*********************

  • 常量应该使用双引号或单引号括起来 [# ‘1’#==#’10’ #].
  • 更好的书写方式:

****************************

a. 中括号内的每一个组件都用空格隔开(可谓釜底抽薪)

b. 变量都以双引号括起来

****************************

参数

-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     若两个字符串不相等,则为真
**********************************************************
参与比较的数字必须能够转化为整数,话说那里有这个语法的manual?
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有一个为真则整式为真

linux 使用中括号进行条件判断的更多相关文章

  1. Linux makefile教程之条件判断六[转]

    使用条件判断 —————— 使用条件判断,可以让make根据运行时的不同情况选择不同的执行分支.条件表达式可以是比较变量的值,或是比较变量和常量的值. 一.示例 下面的例子,判断$(CC)变量是否“g ...

  2. Linux学习 -- Shell编程 -- 条件判断

    按照文件类型进行判断 两种格式 test -e /root/install.log [ -e /root/install.log ]   注意空格  适合用于脚本中 echo $?可以看到结果 [ - ...

  3. Linux之shell编程条件判断-if,while,for,case

    if 语法格式 if condition then statements [elif condition then statements] [else statements ] fi 示例 vi if ...

  4. linux shell中的条件判断语句

    http://bbs.chinaunix.net/thread-396805-1-1.html shell 判断语句 流程控制 "if" 表达式 如果条件为真则执行then后面的部 ...

  5. Linux Shell编程 条件判断语法

    if条件判断语句 单分支 if 条件语句 语法格式: if [条件判断式];then 程序 fi 或者 if [条件判断式] then 程序 fi 在使用单分支 if 条件查询时需要注意几点: if ...

  6. [Shell]条件判断与流程控制:if, case, for, while, until

    ---------------------------------------------------------------------------------------------------- ...

  7. 『忘了再学』Shell流程控制 — 33、if条件判断语句(一)

    目录 1.单分支if条件语句 2.双分支if条件语句 (1)示例1 (2)示例2 什么是流程控制? 普通理解:Shell编写的程序是顺序执行的,也就是说第一命令先执行,然后接着执行第二条命令,然后再下 ...

  8. Shell脚本 (三) 条件判断 与 流程控制

    个人博客网:https://wushaopei.github.io/    (你想要这里多有) 六.条件判断 1.基本语法 [ condition ](注意condition 前后要有空格) 注意:条 ...

  9. 我们一起来学Shell - shell的条件判断

    文章目录 Shell 条件测试语法 符号说明 Shell 测试表达式 文件测试表达式 字符串测试表达式 整数操作符 逻辑操作符 测试表达式的区别总结 Shell 条件判断之if语句 单分支 IF 条件 ...

随机推荐

  1. 【javascript】数据结构-集合

    <!DOCTYPE html> <html> <head> <title>集合</title> <meta charset=" ...

  2. Signing package index... Cannot open file '/home/jello/openwrt/key-build' for reading

    一.环境 发行版:Ubuntu 18.04.1 LTS 代号:bionic 内核版本:4.15.0-30-generic 二.背景 在编译Openwrt/LEDE时出现以下错误,进而自动终止了编译: ...

  3. JAVA8新特性——Lamda表达式

    JAVA9都要出来了,JAVA8新特性都没搞清楚,是不是有点掉队哦~ Lamda表达式,读作λ表达式,它实质属于函数式编程的概念,要理解函数式编程的产生目的,就要先理解匿名内部类. 先来看看传统的匿名 ...

  4. 理解if __name__ == '__main__':

    一开始没怎么注意这个语句,这两天在模拟知乎登陆时准备刨根问底了,先看两行代码片段 第一个例子:这是在login.py文件的一部分,其他我们忽略,只关注print()函数的内容 import time ...

  5. BZOJ 1951 【SDOI2010】 古代猪文

    题目链接:古代猪文 好久没写博客了,这次就先写一篇吧…… 题面好鬼……概括起来就是:给出\(N,G(\leqslant 10^9)\),求:\[G^{\sum_{d|n}\binom{n}{d}} \ ...

  6. lua if 流程控制

    Lua认为false和nil为假,true和非nil为真. 要注意的是Lua中 0 为 true --[ 为 true ] ) then print("0 为 true") end ...

  7. spring boot: 输出json

    spring boot:  输出json 注意:关闭java的Terminate后,在重新启动,否则报错 app.java启动配置 package com.muyang.boot1; import o ...

  8. 剑指offer面试题19 二叉树的镜像

    题目描述 操作给定的二叉树,将其变换为源二叉树的镜像.  输入描述 二叉树的镜像定义:源二叉树 8 / \ 6 10 / \ / \ 5 7 9 11 镜像二叉树 8 / \ 10 6 / \ / \ ...

  9. UVA-129 Krypton Factor(回溯)

    题目大意:由字母A到Z组成的字符串,其中有两个子串完全相同的叫做容易的串,反之叫困难的串.找出由前L个字母组成的第n个困难的串. 题目分析:简单回溯,不过要判断是否存在重复子串比较棘手.<入门经 ...

  10. 处理XML Publisher导出EXCEL值变为科学计数法的问题

    <fo:bidi-override direction="ltr" unicode-bidi="bidi-override"><?PoOrde ...