day 17 操作系统正则符号/grep

系统通配符号:
 *     匹配所有内容
举例:
ls -l /oldboy/*.txt        --- 匹配以.txt结尾信息进行详细显示
rm -rf  /oldboy/*          --- 删除oldboy目录中所有信息, 但是默认无法删除隐藏文件
rm -f   /oldboy/.old*.txt  --- 删除以old开头 .txt结尾的所有隐藏文件   
find /oldboy -name "*.txt"    查找oldboy目录中以txt结尾的所有文件
find /oldboy -name "oldboy*"  查找oldboy目录中以oldboy开头的所有文件
find /oldboy -name "old*.txt"    查找oldboy目录中以old开头以.txt结尾的所有文件
{}        匹配序列信息
 数字序列;字母序列;
 组合序列:使用方法如下
echo A{,2}   ---      A                                                         A2
                  /oldboy/oldboy01/oldboy02/oldboy03/oldboy04/oldboy.txt        .bak
快速备份数据                
cp /oldboy/oldboy01/oldboy02/oldboy03/oldboy04/oldboy.txt{,.bak}
cp /oldboy/oldboy01/oldboy02/oldboy03/oldboy04/oldboy.txt  /oldboy/oldboy01/oldboy02/oldboy03/oldboy04/oldboy.txt.bak
快速还原数据
cp /oldboy/oldboy01/oldboy02/oldboy03/oldboy04/oldboy.txt{.bak,}
cp /oldboy/oldboy01/oldboy02/oldboy03/oldboy04/oldboy.txt.bak  /oldboy/oldboy01/oldboy02/oldboy03/oldboy04/oldboy.txt
cp messages{-20190707,}

系统正则符号:grep sed awk

系统正则: BRE( basic regular expression )
扩展正则:ERE(extended regular expression)

基础正则:
^    以什么开头的信息  举例:

筛选以d开头的信息

$ 以什么结尾的信息

在这个目录文件中以d为结尾的信息

说明:如果结尾有空格信息,过滤是会出现异常现象
利用底行模式:set list可以查看结尾空格信息
利用命令查看:cat-A /etc/selinux/config

问题:将以点为结尾的信息过滤出来
  这个点前面必须加\不加这个符号点有特殊意义
点结尾的信息.png
\(不属于正则符号) 转义符号
    将有意义的特殊符号,还原本身符号的意义
    将没有意义的符号,变成为有意义:\n  \r  换行符    \t 指表符
    [root@oldboyedu ~]# echo -e "oldboy01\noldboy02" >oldboy.txt
    [root@oldboyedu ~]# cat oldboy.txt 
    oldboy01
    oldboy02  实现换行操作
   取消别名
^$ 空行信息
  举例:grep -v "^$" /etc/selinux/config
  表示筛选出文件中的字符 没有空格   -v是grep的参数信息  表示取反的意思
. 表示的是匹配任意一个字符且只能匹配一个字符
grep "^." /etc/selinux/config   匹配任意一个以什么开头的字符
grep".$" /etc/selinux/config    匹配任意一个什么结尾的字符
grep"." /etc/selinux/config      匹配整个文件中所有字符信息
总结匹配筛选文件信息:
   会按照行进行匹配
   会匹配信息贪婪特性
   利用grep -o 可以查看匹配信息过程
* 匹配前一个字符连续出现0次或多次
 举例说明:
 加上*就把文件里面的信息都显示出来然后把你要找的东西标出来  
 如果不加*就把你要找的东西的所在行显示出来
区别.png
.* 匹配文件中所有信息
下图表示的是加上*跟不加*的区别
22.png
[ ]匹配中括号中任意一个字符
图片.png
[^] 将指定字符信息 进行取反筛选过滤
23.png

系统扩展正则符号(高级符号)

grep不识别高级符号 必须加参数 表现形式为egrep 或者是grep -E
sed需加上r 表现形式为sed -r

+ 匹配前一个字符连续出现1次或者多次
"0+"跟"0*"的区别
| 表示匹配多个字符串信息
对比信息和几种方法
( )将多个字符信息进行整合过滤 难点 ★
实现后项引用前项进行替换
小括号和中括号的对比

小括号里面的字符表示的是一个整体信息
中括号里面的字符表示的是一个一个的字符信息


配合sed命令使用方法
( )第一个作用 配合sed命令使用时,可以实现后项引用前项
    echo "123456"|sed -r 's#([0-9]+)#<\1>#g'
    <123456>
    echo "1234567890"|sed -r 's#([0-9])#<\1>#g'
    echo "789"|sed -r 's#(.)(.)(.)#<\1><\2><\3>#g'
    <7><8><9>
    说明: 后项引用前项只能引用1-9个小括号
    
    解锁: 批量创建用户 (密码是随机密码)
    [root@oldboyedu oldboy]# seq -w 10|sed -r 's#(.*)#useradd oldboy\1;echo 123456|passwd --stdin oldboy\1#g'
    useradd oldboy01;echo 123456|passwd --stdin oldboy01
    useradd oldboy02;echo 123456|passwd --stdin oldboy02
    useradd oldboy03;echo 123456|passwd --stdin oldboy03
    useradd oldboy04;echo 123456|passwd --stdin oldboy04
    useradd oldboy05;echo 123456|passwd --stdin oldboy05
    useradd oldboy06;echo 123456|passwd --stdin oldboy06
    useradd oldboy07;echo 123456|passwd --stdin oldboy07
    useradd oldboy08;echo 123456|passwd --stdin oldboy08
    useradd oldboy09;echo 123456|passwd --stdin oldboy09
    useradd oldboy10;echo 123456|passwd --stdin oldboy10
    [root@oldboyedu oldboy]# seq -w 10|sed -r 's#(.*)#useradd oldboy\1;echo 123456|passwd --stdin oldboy\1#g'|bash
    Changing password for user oldboy01.
    passwd: all authentication tokens updated successfully.
    Changing password for user oldboy02.
    passwd: all authentication tokens updated successfully.
    Changing password for user oldboy03.
    passwd: all authentication tokens updated successfully.
    Changing password for user oldboy04.
    passwd: all authentication tokens updated successfully.
    Changing password for user oldboy05.
    passwd: all authentication tokens updated successfully.
    Changing password for user oldboy06.
    passwd: all authentication tokens updated successfully.
    Changing password for user oldboy07.
    passwd: all authentication tokens updated successfully.
    Changing password for user oldboy08.
    passwd: all authentication tokens updated successfully.
    Changing password for user oldboy09.
    passwd: all authentication tokens updated successfully.
    Changing password for user oldboy10.
    passwd: all authentication tokens updated successfully.
{}匹配前一个字符连续出现指定的次数
{n,m}  --- 匹配前一个字符连续出现至少n次 最多m次
       [root@oldboyedu oldboy]# grep -E "0{2,4}" oldboy.txt 
       my qq num is 49000448.
       not 4900000448.
       [root@oldboyedu oldboy]# grep -E "0{2,4}" oldboy.txt -o
       000
       0000
       [root@oldboyedu oldboy]# grep -E "0{1,3}" oldboy.txt -o
       0
       000
       000
       00
       [root@oldboyedu oldboy]# grep -E "0{1,3}" oldboy.txt 
       our site is 0 http://www.etiantian.org
       my qq num is 49000448.
       not 4900000448.
{n}    --- 匹配前一个字符连续出现正好n次
       [root@oldboyedu oldboy]# grep -E "0{3}" oldboy.txt
       my qq num is 49000448.
       not 4900000448.
       [root@oldboyedu oldboy]# grep -E "0{2}" oldboy.txt
       my qq num is 49000448.
       not 4900000448.
{n,}   --- 匹配前一个字符连续出现最少n次, 最多不限
{,m}   --- 匹配前一个字符连续出现最少0次, 最多是m次
       [root@oldboyedu oldboy]# grep -E "0{3,}" oldboy.txt 
       my qq num is 49000448.
       not 4900000448.
       [root@oldboyedu oldboy]# grep -E "0{,3}" oldboy.txt 
       I am oldboy teacher!
       I teach linux.
       
       I like badminton ball ,billiard ball and chinese chess!
       my blog is http://oldboy.blog.51cto.com
       our site is 0 http://www.etiantian.org
       my qq num is 49000448.
       
       not 4900000448.
       my god ,i am not oldbey,but OLDBOY!
? 匹配前一个字符连续出现0次或者1次
? + * 对比

你可能感兴趣的:(day 17 操作系统正则符号/grep)