bash的特性之多命令执行的逻辑关系

  1.命令替换

COMMAND1 $(COMMAND2)  :先执行COMMAND2然后再作为COMMAND1的参数执行COMMAND1

[root@localhost ~]# ls /mnt
a.sh  a.txt
----------------------------------------------------------
[root@localhost mnt]# cat a.sh

echo "你好"
---------------------------------------------------------
[root@localhost mnt]# cat a.txt

useradd xiaoming -c "wang xiaoming" -u 8089 -g 8089
passwd xiaoming -n 5 -x 30 -w 3 -i 7
----------------------------------------------------------- 
[root@localhost ~]# cat $(ls /mnt)

echo "你好"

useradd xiaoming -c "wang xiaoming" -u 8089 -g 8089
passwd xiaoming -n 5 -x 30 -w 3 -i 7

  2.管道

COMMAND1 | COMMAND2 |COMMAND3  :先执行1,然后再把1的结果作为2的参数执行,再把2的结果给三执行


取出 /etc/passw中的第9,10行

[root@localhost ~]# head -10 /etc/passwd|tail -2
mail:x:8:12:mail:/var/spool/mail:/sbin/nologin
operator:x:11:0:operator:/root:/sbin/nologin

  3.顺序执行结构

  COMMAND1;COMMAN2;COMMAND3... :

 

[root@localhost ~]# echo -n "1";echo ";2"

1;2

 


  4.选择执行结构

如果...那么....   

要么...要么....

逻辑运算:

  与 :逻辑乘法  1 --真,0--假 ,&&,双目操作符

1 && 1=1

1 && 0=0

0 && 1=0

0 && 0=0

  "与"运算的断路运算法则 :只要第一个操作数为false,则其逻辑运算结果一定为false;

   


  或 :逻辑加法  1--真,0--假, ||,双目操作符

1 || 1 =1

1 || 0 =1

0 || 1 =1

0 || 0 =0

  "或"运算的短路运算法则:只要第一个操作数为true,则其逻辑运算结果一定为ture

    非 :逻辑取反  1--真,0--假, !,单目操作符

!0=1

!1=0


COMMAND1 && COMMAND2

1.表示如果COMMADN1执行成功,则将会执行COMMAND2

2.表示如果COMMAND2执行失败,则不会执行COMMAND2


COMMAND1 || COMMAND2

1.只有COMMAND1执行失败,COMMAND2才会被执行

2.如果COMMAND1执行成功,COMMAND2不会被执行

!COMMAND1 && COMMAND2  ==  COMMAND1 || COMMAND2

!COMMAND1 || COMMAND2  ==  COMMAND1 && COMMAND2


   德·摩根定律

!(COMMAND1 && COMMAND2) || COMMAND3

!(COMMAND1 || COMMAND2) && COMMAND3


!(A && B) = !A || !B

!(A || B) = !A && !B

   三种逻辑运算的优先级:

!>&&>||

注意:逻辑运算考虑的是其状态返回值


shell脚本编程--bash脚本编程:

      过程式编程语言,解释运行的编程语言,脚本类语言(依靠外部应用程序文件运行)


shell脚本到底是什么?

1.纯文本文档——文件中所有存储或包含的指令+数据都是以字符为单位进行存储的

2.根据用户的需求来解决用户问题的简单或复杂的命令组合体

3.是一种具有“执行幂等性”的程序实体

执行幂等性:任何命令的一次执行结果和多次执行结果时一致的

   注意:很多命令都不具备"执行幂等性",因此在shell脚本中我们需要使用大量的程序逻辑来判断某个命令是否

 符合其运行条件,从而避免在运行过程中出现的严重错误


shell脚本中的代码内容如何出现?

1.首行必须是shebang,即解释器程序的绝对路径,而且必须占据绝对行首;且必须单独占据第一行,在执行脚本时,

 会根据shebang的指示启动相应的解释器以解释脚本内诸多的命令;

#!/bin/bash

#!/bin/sh

#!/usr/bin/python

#!/usr/bin/per1

.....

2.在shell脚本中除了shebang之外,所有行首为#字符的行均被解释为  注释行;即:解释器只会解释其内容,但不

予以执行


3.解释器会忽略脚本文件中所有的空白行;空白行指的是:在一行文本中除了空白字符,空格字符,制表字符之外

不具备其他任何类型的字符的行


4.大量的命令和关键字

   命令:内部或外部应用程序

   关键字:内置于shell,只能在某种特定结构体中执行的命令;keyword;

  如:if,else,then,do,while,for,select,until,case,fi,esac.....

 5.shell中的所有的特殊功能字符

注意:所有被编写进shell脚本文档的字符必须是ASCLL编码格式的字符,其他编码格式的字符可以出现在shell

     脚本文件中,但不具有任何特殊含义



如何编写shell脚本?

   利用所有的文本文档编辑工具进行shell脚本编写,如:

       nano,vi,vim,pico,emacs,...

       通常在Linux的各种发行版本中推荐使用vim;


脚本文件的命名方式:

   一般情况下:我们会为脚本设置".sh"的名称后缀;较低版本的编辑工具会根据文件的后缀名称来识别是否为shell

   脚本文件;较高版本的文本编辑工具,如vim7,无需过多的关系文件后缀名的问题


脚本的运行方法

1.为脚本文件赋予执行权限,可以直接以绝对路径或相对路径的方式运行此文件;

 #chmod +x /PATH/TO/SOME_SCRIPT_FILE

 #/PATH/TO/SOME_SCRIPT_FILE

注意:如果脚本文件所在目录路径存储于PATH变量中,则直接以脚本文件名执行即可


2.直接使用解释器运行脚本,将脚本文件作为解释器程序的参数

 # bash /PATH/TO/SOME_SCRIPT_FILE

bash命令的常用选项:

-x:使bash在解释脚本的过程展示在标准输出上;一般用于帮shell脚本排错

-n:对脚本文件进行预执行,以分析脚本中是否存在语法错误,如果没有错误,则不输出任何信息;

   相反则输出一些简洁的提示性系;具体的错误定位需要自行判断;


注意:此种方式中,脚本文件是否有执行权限并不是很重要的权限

注意:以上俩种方式,执行脚本时,会在当前shell中开启一个新的子shell以运行脚本;一般情况下,当脚本运行结束,该子

      shell也会被随之销毁;因此所有在脚本中定义的变量,在脚本的末尾处,最好将其明确的撤销。


3.使用source命令运行脚本:

  #source /PATH/TO/SOME_SCRIPT_FILE

  # . /PATH/TO/SOME_SCRIPT_FILE


注意:source命令不会在运行脚本时开启子shell,而是在当前shell中执行;

     使用source命令执行的脚本中不要包括诸如exit类的命令



利用bash脚本实现算数运算:

  算术运算操作符

    常用的基本算数运算符:

+ - * /  %  **


    增强型的算数运算符:

+=  -=  *=  /=  %=


    特殊的增强型算术运算符

++  --

 

创建一个变量wc1,如何区分++wc1  ,wc1++ 和 wc1+=
[root@localhost ~]# wc1=4
[root@localhost ~]# echo "$[wc1++]"
4
[root@localhost ~]# echo $wc1
5
wc1++ :将wc1输出,然后再让他的值+1

[root@localhost ~]# echo "$[++wc1]"
6
[root@localhost ~]# echo $wc1
6

++wc1,将wc1的值加1然后再输出

[root@localhost ~]# echo "$[wc1+=4]"
10
[root@localhost ~]# echo $wc1
10

wc1+=4 :将wc1的值加4再赋值给wc1

算术运算方法:


    1.$[expression]

其中的表达式可以是纯数字组成的,也可以使用变量引用变量值;在使用变量时,可以将$符号省略

    

[root@localhost ~]# echo "$[3+4]"
7

    2.let VAR=EXPRESSION

根据算术表达式完成算术运算并赋值给指定的变量

    3.$((EXPRESSION))

其中的表达式可以是纯数字组成的,也可以使用变量引用变量值;在使用变量时,可以将$符号省略

    4.expr ARGU1  ARGU2  ARGU3 

其中ARGU1 和 ARGU3必须是整数数值  ARGU2是算术运算符

    5.echo "EXPRESSION" | bc

    6.bc <<



grep系:Global search Regular Expression and Print out the line

利用正则表达式进行全局搜索并将匹配到的行显示出来 

   语法格式:

       grep [options] PATTERN [FILE...]

       grep [options] [-e PATTERN | -f FILE] [FILE...]


       PATTERN:过滤匹配条件,是由没有特殊意义的文本字符或者是正则表达式元字符组成


正则表达式元字符:会被正则表达式处理引擎解释为特殊含义的字符


pcre:正则表达式处理引擎,prel语言的正则表达式引擎


正则表达式的元字符:

基本的正则表达式元字符:BRE

1.字符匹配类:

   .:匹配任意单个字符

  []:匹配任意指定范围内的单个字符

 [^]:匹配任意指定范围外的单个字符

下列所有的字符集都可以放置于[]之中用于匹配字符集范围内的单个字符


[:lower:] [:upper:] [:alpha:] [:digit:] [:xdigit:] [:alnum:] [:punct:] [:space:]

[a-z]:仅表示所有的小写字母

[A-Z]:仅表示所有的大写字母

[0-9]:仅表示所有的十进制数码

2.次数匹配类: 该字符前面的一个字符可以出现的次数

   *:表示前面的字符可以出现任意次,即:0-n

  \?:表示其前面的字符可有可无,即0次 或 1次

      \+:表示其前面的字符至少出现一次

      \{m,n\}:表示其前面的字符至少出现m次,最多不超过n次

      \{m\}:表示其前面的字符必须出现m次

       \{m,\}:表示其前面的字符至少出现m次

       \{,n\}:表示其前面的字符最多不超过n次


注意:在正则表达式中,表示任意长度的任意字符:.*


      3.位置锚定字符

   行锚定:

行首锚定:^

行尾锚定:$

   字锚定:

字首锚定:\<或\b

字尾锚定:\>或\b

4.分组与前向引用字符:

   \(\):把括号内包含的内容作为一个不可分割的整体来处理

     \1,\2,\3,....:前向引用

 正则表达式处理引擎的内置变量,\1表示前面所出现的第一组小括号中扩选的内容;\2表示第二组

 小括号中的内容


       5.\|:将其左右的字符串当做整体来对待

"C\|cat"   匹配 C 或cat

注意:^"C\|cat"不等于匹配 ^C 或 ^cat,而是^C 或cat


常用选项:

扩展的正则表达式元字符:ERE

基本的正则表达式元字符:BRE

1.字符匹配类:

   .:匹配任意单个字符

  []:匹配任意指定范围内的单个字符

 [^]:匹配任意指定范围外的单个字符

下列所有的字符集都可以放置于[]之中用于匹配字符集范围内的单个字符


[:lower:] [:upper:] [:alpha:] [:digit:] [:xdigit:] [:alnum:] [:punct:] [:space:]

[a-z]:仅表示所有的小写字母

[A-Z]:仅表示所有的大写字母

[0-9]:仅表示所有的十进制数码

2.次数匹配类: 该字符前面的一个字符可以出现的次数

   *:表示前面的字符可以出现任意次,即:0-n

   ?:表示其前面的字符可有可无,即0次 或 1次

       +:表示其前面的字符至少出现一次

        {m,n}:表示其前面的字符至少出现m次,最多不超过n次

       {m}:表示其前面的字符必须出现m次

         {m,}:表示其前面的字符至少出现m次

         {,n}:表示其前面的字符最多不超过n次


注意:在正则表达式中,表示任意长度的任意字符:.*


      3.位置锚定字符

   行锚定:

行首锚定:^

行尾锚定:$

   字锚定:

字首锚定:\<或\b

字尾锚定:\>或\b

4.分组与前向引用字符:

    ():把括号内包含的内容作为一个不可分割的整体来处理

     \1,\2,\3,....:前向引用

 正则表达式处理引擎的内置变量,\1表示前面所出现的第一组小括号中扩选的内容;\2表示第二组

 小括号中的内容


       5.|:将其左右的字符串当做整体来对待

"C|cat"   C    或cat


grep系:

grep:仅支持基本正则表达式元字符

egrep:可以支持扩展正则表达式元字符

fgrep:不支持任何形式的正则表达式元字符,把所有的字符视为普通文本字符



常用选项:

-A num :显示被匹配到的行以及其后num行

-B num :显示被匹配到的行以及其前num行

 -C num :显示被匹配到的行及其前后num行


--color[=WHEN]:以高亮颜色来显示被匹配到的内容

-c --count :不显示被匹配的结果,而是输出被匹配到的行数

-E :相当于执行egrep

-F : --fixed-strings :相当于fgrep

-e :指定多个【模式】在一个命令行中生效

-f :从指定的文件中读取多个PATTERN用于一次搜索

-i :--ignore-case 忽略字母大小写

-o :--only-matching:仅显示被PATTERN匹配到的部分,并且分行显示

-q :--quite,--silent:安静模式;相当于grep > /dev/null

-v :--invert-match:显示没有被匹配到的行


注意:字锚定:是锚定没有被特殊符号分隔的一串字符