bash的多命令执行,shell脚本基础及grep系

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.纯文本文档――文件中所有存储或包含的指令+数据都是以字符为单位进行存储的

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 <<<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]:仅表示所有的十进制数码

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,....:前向引用

正则表达式处理引擎的内置变量,\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:显示没有被匹配到的行


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

相关文章

普通模式 >G 增加当前行到文档末尾处的缩紧层级 $ 移动到本行的末尾 . 相当于一个...
原文连接: https://spacevim.org/cn/layers/lang/elixir/ 模块简介 功能特性 启用模块 快捷键 语言专属...
原文连接: https://spacevim.org/cn/layers/lang/dart/ 模块简介 功能特性 依赖安装及启用模块 启用模...
 =   赋值操作符,可以用于算术和字符串赋值 +        加法计算     -        减法运算...
1.根据包名来查看指定的APP指定数据 adb shell "top | grep com.xxx.xxx" 由于这样打印出来的数...
ctrl+F 向下翻页 ctrl+B 向下翻页 u 取消最近一次操作 U 取消当前行的操作 ZZ 保存当前内容并退出 gg 跳...