欢迎各位兄弟 发布技术文章

这里的技术是共享的

You are here

Linux 基础知识(一) shell的 && 和 || 简单使用 美元符号 问号 艾特 井号 有大用 有大大用 有大大大用

Linux 基础知识(一) shell的&&和|| 简单使用

  shell 在执行某个命令的时候,会返回一个返回值,该返回值保存在 shell 变量 ?? == 0 时,表示执行成功;当 $? == 1 时,表示执行失败。  有时候,下一条命令依赖前一条命令是否执行成功。如:在成功地执行一条命令之后再执行另一条命令,或者在一条命令执行失败后再执行另一条命令等。shell 提供了 && 和 || 来实现命令执行控制的功能,shell 将根据 && 或 || 前面命令的返回值来控制其后面命令的执行。    

 

&&(命令执行控制)    

语法格式如下:        

  command1 && command2 [&& command3 ...]    

1 命令之间使用 && 连接,实现逻辑与的功能。  

2 只有在 && 左边的命令返回真(命令返回值 $? == 0),&& 右边的命令才会被执行。  

3 只要有一个命令返回假(命令返回值 $? == 1),后面的命令就不会被执行。  

#demo1

www@ubuntu4:~/bin/lua$ ls
lua.sh
www@ubuntu4:~/bin/lua$ cp ./lua.sh ./lua_cp.sh && rm ./lua.sh && echo "success" 
success
www@ubuntu4:~/bin/lua$ ls
lua_cp.sh

说明:命令首先从 /home/www/bin/lua/lua.sh 文件复制 到当前目录重命名为lua_cp.sh,执行成功后,使用 rm命令 删除源文件lua.sh;如果删除成功则输出提示信息。

 

||(命令执行控制)

语法格式如下:
  command1 || command2 [|| command3 ...] 

1 命令之间使用 || 连接,实现逻辑或的功能。
2 只有在 || 左边的命令返回假(命令返回值 ?==1||c3? == 0),后面的命令就不会被执行。

#demo1

www@ubuntu4:~/bin/lua$ ls
lua_cp.sh
www@ubuntu4:~/bin/lua$ rm ./tinywan.sh && echo "success" || echo "fail" 
rm: cannot remove ‘./tinywan.sh’: No such file or directory
fail

说明:目录下不存在文件 tinywan.sh,将输出提示信息“fail”,删除失败

#demo2

www@ubuntu4:~/bin/lua$ ls
lua_cp.sh
www@ubuntu4:~/bin/lua$ rm ./lua_cp.sh && echo "success" || echo "fail" 
success
www@ubuntu4:~/bin/lua$ ls
www@ubuntu4:~/bin/lua$ 

说明:目录下存在文件tinywan.sh,将输出提示信息“success”,删除成功


$0 这个程式的执行名字

$n 这个程式的第n个参数值,n=1..9

$* 这个程式的所有参数,此选项参数可超过9个。

$# 这个程式的参数个数

$$ 这个程式的PID(脚本运行的当前进程ID号)

$! 执行上一个背景指令的PID(后台运行的最后一个进程的进程ID号) 执行上一个背景指令的PID(后台运行的最后一个进程的进程ID号)  是父ID????

$? 状态返回值,执行上一个指令的返回值 (显示最后命令的退出状态。0表示没有错误,其他任何值表明有错误)

$- (这里是中短横)显示shell使用的当前选项,与set命令功能相同

$@ 跟$*类似,但是可以当作数组用    然后的话${#@}就是把参数列表当作的数组的长度吗? 看看 关于数组   /node-admin/15463


$# 是传给脚本的参数个数

$0 是脚本本身的名字

$1 是传递给该shell脚本的第一个参数

$2 是传递给该shell脚本的第二个参数

$@ 是传给脚本的所有参数的列表

$* 是以一个单字符串显示所有向脚本传递的参数,与位置变量不同,参数可超过9个

$$ 是脚本运行的当前进程ID号

$? 是显示最后命令的退出状态,状态返回值,0表示没有错误,其他表示有错

# vim xx.sh        #这是用函数方法

#!/bin/bash

#

xx(){

echo "1111111111"

echo $0    # 脚本名称

echo "2222222222"

echo $1        #第一个参数

echo "3333333333"

echo $*         #参数值列表

echo "4444444444"

echo $@     #参数值列表

echo "55555555"

echo $$    # 本进程的进程id???

echo "66666666"

echo $!

echo "77777777"

echo $?       #状态返回值

echo "8888888888"

echo $-

echo "999999999"

echo ${@}   #参数值列表

echo "AAAAAAAAAAA"

echo ${*}       #参数值列表

echo "BBBBBBBB"

echo ${#}       #参数个数

echo "CCCCCCCCC"

echo ${#@}        #参数个数

echo "DDDDDDDDD"

echo ${@#}     #参数值列表

echo "EEEEEEEEE"

echo ${#*}        #参数个数

echo "FFFFFF"

echo $#        #参数个数

}

xx a b c

 

# bash xx.sh    #结果如下

1111111111

xx.sh

2222222222

a

3333333333

a b c

4444444444

a b c

55555555

26774

66666666


77777777

0

8888888888

hB

999999999

a b c

AAAAAAAAAAA

a b c

BBBBBBBB

3

CCCCCCCCC

3

DDDDDDDDD

a b c

EEEEEEEEE

3

FFFFFF

3


[root@ha1 test]# vim yyy.sh               #这是用脚本文件名的方法,执行脚本后发现结果与函数是一样的

echo $@

echo "55555555"

echo $$

echo "66666666"

echo $!

echo "77777777"

echo $?

echo "8888888888"

echo $-

echo "999999999"

echo ${@}

echo "AAAAAAAAAAA"

echo ${*}

echo "BBBBBBBB"

echo ${#}

echo "CCCCCCCCC"

echo ${#@}

echo "DDDDDDDDD"

echo ${@#}

echo "EEEEEEEEE"

echo ${#*}

echo "FFFFFFFF"

echo $#



[root@ha1 test]# ./yyy.sh a b c    #执行脚本

1111111111

./yyy.sh

2222222222

a

3333333333

a b c

4444444444

a b c

55555555

28313

66666666


77777777

0

8888888888

hB

999999999

a b c

AAAAAAAAAAA

a b c

BBBBBBBB

3

CCCCCCCCC

3

DDDDDDDDD

a b c

EEEEEEEEE

3

FFFFFFFF

3











复制代码
$0   当前脚本的文件名
$1 ~ $n?   位置参数,为从1开始的数字,当n超过9后,使用${n},例如${10},$1是第一个参数,$2是第二个参数,${10}是第十个参数        #美元符号 1
$#   传入脚本的参数的个数    #美元符号 井号 
$*   所有的位置参数,但视为一个字符串  #美元符号 星号
$@   所有以空白隔开的位置参数,即代表各位置参数组成的串行(每个都作为独立的字符串,可用  “for 变量 in 串行” 循环输出)。  # 美元符号 艾特符号
$?   当前Shell进程中,上一个命令的返回值,如果上一个命令成功执行则$?的值为0,否则为其他非零值,常用做if语句条件  # 美元符号 问号
$$   当前Shell进程的pid            #两个美元符号
$!   后台运行的最后一个进程的pid          # 美元符号 感叹号
$-   显示Shell使用的当前选项          # 美元符号 中短横 (减号)
$_   之前命令的最后一个参数          # 美元符号 下短横 
复制代码

#demo1

复制代码
#!/bin/bash
echo "\$# = 传入脚本的参数的个数: $#"
echo "\$0 = 当前脚本的文件名: $0"
echo "\$1 = first : $1"
echo "\$2 = second: $2"
echo "\$@ = 所有以空白隔开的位置参数: $@"
echo "\$* = 所有的位置参数,但视为一个字符串: $*"
echo "\$$ = 当前Shell进程的pid process id: $$"
echo "\$? = 当前Shell进程中,上一个命令的返回值: $?"
复制代码

执行结果:

复制代码
www@ubuntu4:~/bin$ ./test2.sh var1 var2 var3 var4 var5 var6 
$# = 传入脚本的参数的个数: 6
$0 = 当前脚本的文件名: ./test2.sh
$1 = first : var1
$2 = second: var2
$@ = 所有以空白隔开的位置参数: var1 var2 var3 var4 var5 var6
$* = 所有的位置参数,但视为一个字符串: var1 var2 var3 var4 var5 var6
$$ = 当前Shell进程的pid process id: 167270
$? = 当前Shell进程中,上一个命令的返回值: 0
复制代码

在 [[ 判断式 ]] 中,如果使用 == 或 != ,且在这两个运算符右方的字符串没有加上单引号或双引号,则 == 和 != 会视为想要对比该字符串所形成的“样式”,如果相等,传回0,如果不符,传回1。

#!/bin/bash
 
a="str"
if [[ $a == ??? ]]; then
    echo "Match"
fi

行4,[[ a==???]]a 的值,对比样式 ??? (3个字符的字符串)。

但如果把行4改成:

if [[ $a == "???" ]]; then

那意思就不同了,此时 == 变成了是判断 $a 和 字符串 ??? 是否相等。


来自  https://www.cnblogs.com/tinywan/p/6835531.html


普通分类: