Linux再学--shell基础5正则表达式和文本搜索

1. 元字符

当我们需要使用字符去匹配一个字符串的时候,除了使用一个个字符去字符串中一对一的比对外,匹配中我们还有需要某一种模式的匹配,代表这些模式的字符就称为元字符,常用如下:

  • .匹配除换行符外的任意单个字符
  • *匹配任意一个跟在它前面的字符
  • []匹配方括号中的字符类中的任意一个
  • ^匹配开头
  • $匹配结尾
  • \转义后面的特殊字符

2. 扩展元字符

除了常用的元字符外还有一种扩展字符,常用的如下:

  • +匹配前面的正则表达式至少出现一次
  • ?匹配前面的正则表达式出现零次或一 次
  • |匹配它前面或后面的正则表达式

3. 文件的查找命令find

主要用于在目录中查找文件,常用方式:

find 路径 查找条件 [补充条件]

一般我们都是根据文件名去配 ,-name就可以根据文件名去匹配使用方式如下:

find  /etc -name pas*

当我们无法确定具体文件名的时候可以使用正则的方式去匹配查找:
例如:我们可以使用下列命令查找etc的password文件:

find  /etc -regex .*wd

执行结果如下:
在这里插入图片描述

4. 文本内容的过滤 grep

查找文本中含有关键字的一行;

  • 字符串匹配:
    例如:我们要通过某个关键字过滤日志内容,cd到当前文件后:
grep "Got message" test.log

执行后我们能获取到以下结果:
在这里插入图片描述
这是一个sock.io和服务通信的日志,我们过滤后就能精简日志便于分析;

  • 元字符匹配
    当我们不确定内容中是不是有某个字符或完整的字符的时候可以使用元字符匹配;
grep Got... test.log

执行后的结果:
在这里插入图片描述
注意和通配符中*不同,元字符中想要达到通配符的效果需要使用.*的组合;
例如我们使用下面的方式匹配:

扫描二维码关注公众号,回复: 14240650 查看本文章
  • 按照类型匹配 -type 后面跟 d是目录,f是文件:
    使用方式如下:
find /etc -type f -regex .*wd

执行后的查找结果:
在这里插入图片描述

grep Go.* test.log

执行后的结果;
在这里插入图片描述
可以看到匹配是从关键词开始匹配到了一行的结尾;
还有就是当我们不确定开头是不是大写的时候我们需要使用[]去匹配实例如下:

grep [Gg]o.* test.log

执行的效果和上面类似只不过这里可以匹配不管是大写还是小写的任意内容;
在这里插入图片描述
这次不但匹配到了大写的G,同时也匹配到了消息的g;

猜你喜欢

转载自blog.csdn.net/lym594887256/article/details/125153702