bash的特性之多命令执行的逻辑关系
1.命令替换
COMMAND1 $(COMMAND2) :先执行COMMAND2然后再作为COMMAND1的参数执行COMMAND1
[root@localhost~]#ls/mnt a.sha.txt ---------------------------------------------------------- [root@localhostmnt]#cata.sh echo"你好" --------------------------------------------------------- [root@localhostmnt]#cata.txt useraddxiaoming-c"wangxiaoming"-u8089-g8089 passwdxiaoming-n5-x30-w3-i7 ----------------------------------------------------------- [root@localhost~]#cat$(ls/mnt) echo"你好" useraddxiaoming-c"wangxiaoming"-u8089-g8089 passwdxiaoming-n5-x30-w3-i7
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.纯文本文档――文件中所有存储或包含的指令+数据都是以字符为单位进行存储的
3.是一种具有“执行幂等性”的程序实体
执行幂等性:任何命令的一次执行结果和多次执行结果时一致的
注意:很多命令都不具备"执行幂等性",因此在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 <<<EXPRESSION
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]:仅表示所有的十进制数码
*:表示前面的字符可以出现任意次,即: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]:仅表示所有的十进制数码
*:表示前面的字符可以出现任意次,即:0-n
?:表示其前面的字符可有可无,即0次 或 1次
+:表示其前面的字符至少出现一次
{m,n}:表示其前面的字符至少出现m次,最多不超过n次
{m}:表示其前面的字符必须出现m次
{m,}:表示其前面的字符至少出现m次
{,n}:表示其前面的字符最多不超过n次
注意:在正则表达式中,表示任意长度的任意字符:.*
3.位置锚定字符
行锚定:
行首锚定:^
行尾锚定:$
字锚定:
字首锚定:\<或\b
字尾锚定:\>或\b
4.分组与前向引用字符:
():把括号内包含的内容作为一个不可分割的整体来处理
\1,\2,....:前向引用
正则表达式处理引擎的内置变量,\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 :指定多个【模式】在一个命令行中生效
-i :--ignore-case 忽略字母大小写
-o :--only-matching:仅显示被PATTERN匹配到的部分,并且分行显示
-q :--quite,--silent:安静模式;相当于grep > /dev/null
-v :--invert-match:显示没有被匹配到的行
注意:字锚定:是锚定没有被特殊符号分隔的一串字符