读shell基础:执行顺序(||及&&,{}及())及正则表表达式 【()和{}的用处】

文章来源:http://blog.chinaunix.net/uid-23733005-id-76686.html【多篇文章将shell基础,可以去观看】


读完这个,&&和||仍然没有花心思去看,所以还木有理解。先说说后面的正则表达式吧!觉得挺好玩的!

之前先看看()和{}的区别:(注意:前括后的后面和后括号的前面是有空格的)
当你希望执行读多个命令的时候,会用到上面的两个括号。
(cmd1;cmd2;...;cmdN)#在一个子shell里执行一组命令 
{cmd1;cmd2;...;cmdN}# 在当前shell里执行一组命令 
这是一个基本概念!!!!!!!!!!!!

例子:
[jason@firewall jason]$ A=1;echo $A;{ A=2; };echo $A 


[jason@firewall jason]$ A=1;echo $A;( A=2; );echo $A 



{ A=2; }改变了当前shell变量的值 
( A=2; )未改变当前shell变量的值 

下面回到正则表达式:
一些基本的:
^ 只只匹配行首
$ 只只匹配行尾
* 只一个单字符后紧跟*,匹配0个或多个此单字符
[ ] 只匹配[ ]内字符。可以是一个单字符,也可以是字符序列。可以使用-
表示[ ]内字符序列范围,如用[ 1 - 5 ]代替[ 1 2 3 4 5 ]
\ 只用来屏蔽一个元字符的特殊含义。因为有时在s h e l l中一些元字符有
特殊含义。\可以使其失去应有意义
. 只匹配任意单字符
p a t t e r n \ { n \ } 只用来匹配前面p a t t e r n出现次数。n为次数
p a t t e r n \ { n,\ } m 只含义同上,但次数最少为n
p a t t e r n \ { n,m \ } 只含义同上,但p a t t e r n出现次数在n与m之间

详细例子:
例如,使用ls -l命令,并匹配目录。

$ ls -l | grep ^d

列出文件httpd1.conf中所有以单词common结尾的行
$grep common$ httpd1.conf

匹配所有空行:^ $

只返回包含一个字符的行:^.$


使用\{\}匹配模式结果出现的次数
使用*可匹配所有匹配结果任意次,但如果只要指定次数,就应使用\ { \ },

QUOTE:
此模式有三种形式,即:
pattern\{n\} 匹配模式出现n次。
pattern\{n,\} 匹配模式出现最少n次。
pattern\{n,m} 匹配模式出现n到m次之间,n , m为0 - 2 5 5中任意整数。
(这个和shell小脚本那个模式匹配有点相似???)

匹配字母A出现两次,并以B结尾:
A \ { 2 \ } B
匹配值为A A B

匹配A至少4次:
A \ { 4 , \ } B
可以得结果A A A A B或A A A A A A A B,但不能为A A A B。

如给出出现次数范围,例如A出现2次到4次之间
A \ { 2 , 4 \ } B


下面是常用的选项:
^ 对行首
$ 对行尾
^ [ t h e ] 对以t h e开头行
[ S s ] i g n a [ l L ] 对匹配单词s i g n a l、s i g n a L、S i g n a l、S i g n a L
[Ss]igna[lL]\. 对同上,但加一句点
[ m a y M A Y ] 对包含m a y大写或小写字母的行
^ U S E R $ 对只包含U S E R的行
[tty]$ 对以t t y结尾的行
\ . 对带句点的行
^ d . . x . . x . . x 对对用户、用户组及其他用户组成员有可执行权限的目录
^ [ ^ l ] 对排除关联目录的目录列表
[ . * 0 ] 对0之前或之后加任意字符
[ 0 0 0 * ] 对0 0 0或更多个
[ iI] 对大写或小写I
[ i I ] [ n N ] 对大写或小写i或n
[ ^ $ ] 对空行
[ ^ . * $ ] 对匹配行中任意字符串
^ . . . . . . $ 对包括6个字符的行
[a- zA-Z] 对任意单字符
[ a - z ] [ a - z ] * 对至少一个小写字母
[ ^ 0 - 9 \ $ ] 对非数字或美元标识
[ ^ 0 - 0 A - Z a - z ] 对非数字或字母
[ 1 2 3 ] 对1到3中一个数字
[ D d ] e v i c e 对单词d e v i c e或D e v i c e
D e . . c e 对前两个字母为D e,后跟两个任意字符,最后为c e
\ ^ q 对以^ q开始行
^ . $ 对仅有一个字符的行
^\.[0-9][0-9] 对以一个句点和两个数字开始的行
' " D e v i c e " ' 对单词d e v i c e
D e [ V v ] i c e \ . 对单词D e v i c e或d e v i c e
[ 0 - 9 ] \ { 2 \ } - [ 0 - 9 ] \ { 2 \ } - [ 0 - 9 ] \ { 4 \ } 对日期格式d d - m m - y y y y
[ 0 - 9 ] \ { 3 \ } \ . [ 0 - 9 ] \ { 3 \ } \ . [ 0 - 9 ] \ { 3 \ } \ . [ 0 - 9 ] \ { 3 \ } 对I P地址格式nnn. nnn.nnn.nnn
[ ^ . * $ ] 对匹配任意行

记住:点是匹配单个任意字符

你可能感兴趣的:(读shell基础:执行顺序(||及&&,{}及())及正则表表达式 【()和{}的用处】)