Linux特殊符号浅谈

时间:2021-04-28 09:35:13

Linux特殊字符浅谈

我们经常跟键盘上面那些特殊符号比如(?、!、~...)打交道,其实在Linux有其独特的含义,大致可以分为三类:Linux特殊符号、通配符、正则表达式。

Linux特殊符号又可以分以下几类

1、管道符号

字符

名称

功能描述

|

管道

传递的普通的字符串,来自于前一个命令

|xargs

管道流转换

与xargs 传递的是把字符串变成了文件名

2、目录结构

字符

名称

功能描述

.

当前目录

..

当前目录上一级目录

3、重定向符号

字符

名称

功能描述

>

输出重定向

会清空原文以及内容 然后在向文件里面追加内容

>>

追加输出重定向

追加到文件最后一行

<

输入重定向

文本内容输入 tr xargs

<<

追加输入重定向

用于给文件追加多行文本 cat

4、其他特殊符号  

字符

名称

功能描述

#

注释

Linux注释,另#root 超级用户提示符

$

变量符号

shell、$变量取值、AWK取列等

&&

表示并且

前面部分执行成功才执行后面的部分

||

表示或者

前面部分执行失败才执行后面的部分

``

Shell执行命令

引用命令的结果

;

命令分割

一行分割多个命令,没有逻辑联系

‘’

设置字符串变量

不具有变量置换功能,输出时所见即所得

“”

设置字符串变量

具有变量置换功能,解析变量输出

{}

表示序列

以逗号分割,且不能为空,如{a,b,c}表示单独 {0..9}表示范围,同功能的有seq,但seq只产生数字序列

-

cd -  su - root

~

当前目录的家目录

/

根或者路径分割

!

vi/vim强制退出

逻辑运算非,

!+字母 调出最近一次以字母开头的命令

!!使用 最近一次操作的命令

!+数字 调出历史的第几条命令

通配符:通常匹配文件名

字符

名称

功能描述

?

匹配任一个字符(不在括号内的时候)

*

匹配任何字符(0或多个)

[]

匹配符号内任一字符 如[abcd] [0-9]

[!]非

表示不匹配[]里面任一字符

正则表达式:处理大量的字符串,通常以行为单位(简单高效)

基础正则BRE

字符

名称

功能描述

^

以某某开头的

$

以某某结尾的

^$

空行,不是空格

.

表示任意一个字符

\

元字符转义普通字符

\. 普通字符小数点

\n 换行符

\b 单词边界

\r 回车

\t 横向制表符

*

重复之前的字符0个或者多个

.*

匹配所有字符

^.*

以任意多个字符开头

.*$

以任意多个字符结尾

[]

匹配字符串内的任意一个字符,如[abc]匹配a或b或c,[a-z]匹配所有小写字母

[^]

匹配不包含字符串内的任意字符,取反

 扩展正则ERE(使用egrep或者sed -r)

字符

名称

功能描述

+

重复前一个字符一次或一次以上,如[0-9]+

?

重复前一个字符0次或者一次

|

元字符左边字符或者右边字符

()

分组过滤,如()内的内容为一个整体;反向引用:如\1表示引用第一个()里面的内容

a{n,m}

重复前面a字符n到m次,egrep或者sed -r直接使用,如grep,sed使用该功能需要转义a\{n,m\}

a{n,}

重复前面a字符至少n次

a{n}

重复前面a字符n次

a{,m}

重复前面a字符最多m次

学习正则表达,我们可以使用Linux运维三剑客:awk、sed、grep;除了前三者,正则表达式还支持各种编程或者脚本语言

为了更好的学习和工作,我们一般自动添加颜色来区分匹配关键字

cat >> /etc/bashrc << EOF

alias egrep='egrep --color=auto'

alias grep='grep --color=auto'

EOF

source /etc/bashrc

学习步骤:

1:grep /RE/ filename

2:grep -o /RE/ filename 看它如何匹配

区分正则表达式和通配符

表达式是文件或者目录名       -->通配符

表达式是文件内容(字符串)      -->正则表达式

学习正则方法:awk、sed -r、grep/egrep -o:该都是匹配正则,其他都是通配符

帮助文档:通配符man 7 glob

正则表达式:man grep、info grep等等

举例:

1、/etc/hosts 取该文件权限对应的数字内容 如:-rw-r--r--对应的为644

思路方法:sed 正则、awk 分割符、grep、cut、ls 替换、stat、head

stat /etc/hosts | sed -n '4p' | sed 's#^.*(0##g' | sed 's#/.*$##g'

stat /etc/hosts | sed -rn '4s#^.*\(0(.*)/-.*$#\1#gp'

stat /etc/hosts | awk 'NR==4' | awk -F "0" '{print $2}' | cut -c 1-3

stat /etc/hosts | awk 'NR==4' | awk -F "0" '{print $2}' | awk -F "/" '{print $1}'

stat /etc/hosts | awk 'NR==4' | awk -F "[0/]" '{print $2}'

stat /etc/hosts | awk 'NR==4' | awk -F "0|/" '{print $2}'

stat /etc/hosts | awk -F "[0/]" 'NR==4{print $2}'

ls -l /etc/hosts | cut -c 2-10 | tr "rwx-" "4210" | awk -F "" '{print $1+$2+$3 $4+$5+$6 $7+$8+$9}'

ls -l /etc/hosts | cut -c 2-10 | tr "rwx-" "4210" | awk -F "" '{for(i=1;i<=NF;i++){if(i<4){user[a]+=$i}else if(i>3&&i<7){group[b]+=$i}else{other[c]+=$i}};print user[a]group[b]other[c]}'

ls -l /etc/hosts | awk -F "" '{gsub("r","4")};{gsub("w","2")};{gsub("x","1")};{gsub("-","0");print $2+$3+$4 $5+$6+$7 $8+$9+$10}'

2、取IP地址

ifconfig eth0 | awk -F "[ :]+" 'NR==2{print $4}'

ifconfig eth0 | awk -F "addr:| Bcast:" 'NR==2{print $2}'