linux符号与正则表达式

时间:2023-03-09 23:54:26
linux符号与正则表达式

特殊符号

   >    或者1>   标准输出重定向 先把文件的内容清空  再放入新的内容

>> 或   2>>  追加重定向  把内容放入文件的最后一行

1     表示执行正确的内容才能通过漏斗

2>                标准错误重定向   错误的内容才能通过漏斗

2>>              错误追加重定向   eho hello >>/data/oldboy.txt   2>&1 对的错的都放入文件中

<                 输入重定向  给文件能容分列xargs -n2 </data/num.txt  把文件内容分为两列

<<               追加输入重定向 逐行输入内容

cat >>/data/oldboy.txt<<EOF

I
                           am
                           studying-
                           linux
                           EOF

~                    当前用户的家目录 root  ~  ==/root       oldboy~ ===/home/oldboy

!                    查找并运行历史命令 !awk 包含awk的命令 运行最近的一条

history |grep awk awk历史命令

#                    注释   或root用户的命令提示符

$                    取出变量的内容

awk  $取出某一行的内容   或普通用户的命令提示符

*                      表示所有

\                      转义字符  或撬棍

\n 换行符

\b 单词边界

\r 回车

\t 横向制表符

\. 普通字符小数点消除.点的正则

&&                  前一个命令执行成功然后执行后一个命令

||                      前一个命令执行失败再执行后面的命令

$(    )      ()里的结果留下交给前面的命令处理 #cp   $(find /app/logs/ -type f -name "*.log")   /tmp/a/

$(    )=== `` 反引号

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

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

;              多条命令同时依次执行 相互不依赖

{  }            生成序列 # echo {1..10}   echo stu{01..10} 用作备份cp   oldboy.txt{,.bak}

正则表达式

基础正则BRE  grep 、sed 、awk 

     ^       以某某字符开头

     $       以某个字符结尾

^$     表示空行 不是空格

.        点表示任意字符

*       重复上一个字符0次或>=1次

.*      表示所以字符

^.*     以任意多个字符开头

.*$    以任意多个字符结尾

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

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

扩展正则ERE  egrep、sed -r、awk

+      重复上一个字符一次或一次以上,常与[ ]使用  [0-9]+匹配连续数字

?      重复上一个字符0次或者一次

{n,m}重复前面a字符n到m次

{n, }   重复前面a字符至少n次

{ ,m}  重复前面a字符最多m次

{n}     重复前面a字符n次

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

|         匹配左边字符或者右边字符

使用举例 执行命令取出 linux 中 eth0 的 IP 地址

[root@oldboyedu01-nb ~]# ifconfig eth0|awk 'NR==2'

inet addr:10.0.0.200 Bcast:10.0.0.255 Mask:255.255.255.0

[root@oldboyedu01-nb ~]# ifconfig eth0|awk 'NR==2'|awk '{print $2}'

addr:10.0.0.200
     [root@oldboyedu01-nb ~]# ifconfig eth0|awk 'NR==2'|awk '{print $2}'|awk
 -F":" '{print $2}'
10.0.0.200

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

2# ifconfig eth0|sed -n '2p'|sed -r 's#^.*dr:(.*)  Bc.*$#\1#g'

3#ifconfig  eth0|sed  -nr  '2s#^.*dr:(.*)  Bc.*$#\1#gp'

如何取得/etc/hosts 文件的权限

stat /etc/hosts |awk 'NR==4'

Access: (0644/-rw-r--r--) Uid: ( 0/ root) Gid: ( 0/root)

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

0644

stat /etc/hosts |sed -nr '4s#^.*\(([0-9]+).*$#\1#gp'

0644

stat -c%a /etc/hosts

0644

使用小结 sed 反向引用  awk指定分割符