day18
操作系统正则符号/grep
1.系统通配符号
2.系统正则符号
知识回顾:
1.系统文件属性(文件类型 权限信息 用户信息 inode / block 硬链接 软链接)
find -ls --- 找到数据之后显示数据的属性信息
2.系统符号信息 (基础符号)
基础符号系列: # $ ! |
引号符号系列: "" '' `` 没引号
路径符号系列: ~ - .. .
重定向符号: > >> 2> 2>> < <<
正确信息/错误信息 &>>/oldboy.log
正确信息/错误信息 >>/oldboy.log 2>&1
逻辑符号系列: && 先执行符号前面的命令, 命令执行正确,再执行符号后面的命令
|| 先执行符号前面的命令, 命令执行失败,再执行符号后面的命令
; 多个命令同时执行
系统通配符号
1 * --- 匹配所有
ls -l /oldboy/.txt --- 匹配以.txt结尾信息进行详细显示
rm -rf /oldboy/ --- 删除oldboy目录中所有信息,膳食默认无法删除隐藏文件
rm -f /oldboy/.old星.txt --- 删除以old开头.txt结尾的所有隐藏文件
find /oldboy -name ".txt"
find /oldboy -name "oldboy"
find /oldboy -name ".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,}
系统正则符号:
基础正则: basic regular expressin BRE
扩展正则: extended regular expression ERE
终极目标:
1.文件test.txt
张三 123852
李四 354851
王五 absjdf
如何找出不规范的???
grep -vE "[0-9]+" test.txt
2.如何取出IP地址信息???
基础正则:
^ --- 以什么开头的信息
[root@han ~]# grep "^#" /etc/services
" /etc/selinux/config
SELINUX=disabled
[root@han ~]# grep ".$" /etc/selinux/config
说明:
如果结尾有空格信息,过滤信息会出现异常
利用底行模式: set list 可以查看结尾信息
利用命令查看: cat -A /etc/selinux/config
(不属于正则) --- 转义符号
01.将没有意义的字符,变为有意义
- 将有意义的字符 还原本意
\n --- 换行符
echo -e "oldboy01\noldboy02">oldboy.txt
\t --- 制表符(对齐一列)
03.取消别名操作
\rm
如何过滤空行信息不显示?
grep -v "^" (举两个栗子)
总结匹配筛选文件信息:
01.会按照行进行匹配(一行一行匹配)
02.匹配时有贪婪特性
03.利用 grep -o 可以查看匹配信息的过程
- --- 匹配前一个字符连续出现0次或者多次
测试:
[root@han oldboy01]# grep "0*" oldboy.txt
hekfjdhaskf000sadf
asdfdas00000adsfasd
sadfasd00sadfasd
.* --- 匹配文件中所有信息
测试
[root@han oldboy01]# grep ".*" oldboy.txt
hekfjdhaskf000sadf
asdfdas00000adsfasd
sadfasd00sadfasd
[ ] --- 匹配中括号中任意一个字符
测试
[root@han oldboy01]# grep "[ad]" oldboy.txt
hekfjdhaskf000sadf
asdfdas00000adsfasd
sadfasd00sadfasd
过滤出所有的小写字母:
测试
[root@han oldboy01]# grep "[a-z]" oldboy.txt
hekfjdhaskf000sadf
asdfdas00000adsfasd
sadfasd00sadfasd
[^] --- 中括号内尖角号之后的内容进行取反
[root@han oldboy01]# grep "[^a-z]" oldboy.txt
^[a-zA-Z]匹配以字母开头
[root@han oldboy01]# grep "^[a-z]" oldboy.txt
系统扩展正则(高级符号)
grep (egrep grep - E)
sed (sed -r) 使用以下符号时需要按照括号内格式写
- --- 匹配前一个字符连续出现一次或多次
grep "0+" oldboy.txt
| --- 匹配多个信息
匹配oldboy和oldbey单词信息
grep "oldb[eo]y" oldboy.txt
grep "oldb.y" oldboy.txt
egrep "oldboy|oldbey" oldboy.txt
企业应用:配置文件有注释有空行的如何取消
grep -vE "$|#" /etc/services
( ) --- 将多个字符进行整合过滤
第一个作用实践说明
第二个作用:配合sed命令使用时,可以实现后项引用前项 eccho (1)(2)
解锁:批量创建用户
{ } --- 匹配前一个字符连续出现指定的次数
{n,m} --- 匹配前一个字符连续出现至少n次 最多m次
{n} --- 匹配前一个字符正好出现n次
{n,} --- 匹配前一个字符连续出现最少n次 最多不限
{,m} --- 匹配前一个字符连续出现最多m次 最少不限
? --- 前一个字符连续出现0次或者1次 都会显示而且带有字符会红 不带的也会显示出来
总结;
通配符号: 匹配文件名称
正则符号: 匹配文件内容