前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >学习笔记0409----正则三剑客之grep

学习笔记0409----正则三剑客之grep

作者头像
嘻哈记
发布2022-01-11 10:39:30
5340
发布2022-01-11 10:39:30
举报

正则三剑客之grep

预习内容

任务列表 9.1 正则介绍_grep上 9.2 grep中 9.3 grep下 扩展 把一个目录下,过滤所有*.php文档中含有eval的行 grep -r --include="*.php" ‘eval’ /data/

1.grep 过滤指定关键词

在这里插入图片描述
在这里插入图片描述

1.1 grep选项参数

参数

作用

-c

计算符合范本样式的列数

-i

忽略字符大小写

-n

在显示符合范本样式的那一行之前,标示出该行的行号

-v

取反

-r

遍历所有子目录

-o

只显示符合RE的字符串

-A

后面跟数字,除了显示符合范本样式的那一行之外,并显示该行之后n行的内容

-B

后面跟数字,除了显示符合范本样式的那一行之外,并显示该行之前n行的内容

-C

后面跟数字,除了显示符合范本样式的那一行之外,并显示该行之前于之后n行的内容

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

1.2 正则特殊符号作用

字符匹配:
.	任意单个字符
[]	指定范围内的任意单个字符
[^] 指定范围外的任意单个字符

次数匹配:
*:匹配其前一个字符任意次;
?: 匹配其前一个字符0或1次;
+: 匹配其前一个字符至少1次
{m}: 匹配其前一个字符m次;
{m,n}: 至少m次,至多n次
{m,}: 至少m次;
{0,n}:至多n次;

锚定:
^: 行首
$: 行尾
\<, \b: 词首
\>, \b:词尾

分组:
(): 分组
|: 或者, ac|bc
grep -E "con(C|c)at"  匹配conCat或concat
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

扩展阅读: 正则表达式全部符号解释 17个案例带你3分钟搞定Linux正则表达式

1.3 grep与正则表达式的一起使用

[root@linux-01 ceshi]# grep 'r.o' passwd    //r.o中的点代表任意一个字符
在这里插入图片描述
在这里插入图片描述
//  * 代表左边的字符重复0次或者任意次数
[root@linux-01 ceshi]# grep 'r*o' passwd   
#Root:x:0:0:root:/root:/bin/bash
#bin:x:1:1:bin:/bin:/sbin/nologin
daemon:x:2:2:daemon:/sbin:/sbin/nologin
adm:x:3:4:adm:/var/adm:/sbin/nologin
lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin
shutdown:x:6:0:shutdown:/sbin:/sbin/shutdown
mail:x:8:12:mail:/var/spool/mail:/sbin/nologin
operator:x:11:0:operator:/root:/sbin/nologin
games:x:12:100:games:/usr/games:/sbin/nologin
ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin
nobody:x:99:99:Nobody:/:/sbin/nologin
systemd-network:x:192:192:systemd Network Management:/:/sbin/nologin
dbus:x:81:81:System message bus:/:/sbin/nologin
polkitd:x:999:998:User for polkitd:/:/sbin/nologin
sshd:x:74:74:Privilege-separated SSH:/var/empty/sshd:/sbin/nologin
postfix:x:89:89::/var/spool/postfix:/sbin/nologin
xihaji:x:1000:1000::/home/xihaji:/bin/bash
xihaji2:x:1001:1001::/home/xihaji2:/bin/bash
readonly:x:1002:1002::/home/readonly:/bin/bash
roooooor
o1o
r?o
r-o
r5o
r=o
r.o
o111o
oo
user1:x:1003:100::/home/user1:/bin/bash
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

课后总结

1. Linux 系统添加操作记录审计

1.mkdir -p /usr/local/domob/records/      //创建一个文件夹用于存储历史命令
 
  chmod 777 /usr/local/domob/records/   //给与这个文件夹777的权限
 
  chmod +t /usr/local/domob/records/     //给文件夹增加-t权限,防止删除
 
2.vim /etc/profile 在最后添加下面的代码
 

if [ ! -d  /usr/local/domob/records/${LOGNAME} ]   //查看这个文件夹是否存在
 
then
 
mkdir -p /usr/local/domob/records/${LOGNAME}    //不存在创建这个文件夹
 
chmod 300 /usr/local/domob/records/${LOGNAME}   //给文件夹300的权限
 
fi
 
export HISTORY_FILE="/usr/local/domob/records/${LOGNAME}/bash_history"   //创建一个变量
 
export PROMPT_COMMAND='{ date "+%Y-%m-%d %T ##### $(who am i |awk "{print \$1\" \"\$2\" \"\$5}") #### $(history 1 | { read x cmd; echo "$cmd"; })"; } >>$HISTORY_FILE' 
//上面这条命令是在每个操作前执行,把history的最后一条命令写入到一个文件当中。
// date "+%Y-%m-%d %T   时间
//$(who am i |awk "{print \$1\" \"\$2\" \"\$5}")   用户,登录地址
//(history 1 | { read x cmd; echo "$cmd"; })    历史命令
测试结果如下:
[root@linux-01 ceshi]# mkdir -p /usr/local/domob/records/ 
[root@linux-01 ceshi]# chmod 777 /usr/local/domob/records/ 
[root@linux-01 ceshi]# chmod +t /usr/local/domob/records/ 
[root@linux-01 ceshi]# vim /etc/profile

重新开启一个终端
Connecting to 192.168.141.128:22...
Connection established.
To escape to local shell, press 'Ctrl+Alt+]'.

WARNING! The remote SSH server rejected X11 forwarding request.
Last login: Thu Mar 21 04:34:04 2019
[xihaji@linux-01 ~]$ 
[xihaji@linux-01 ~]$ pwd
/home/xihaji
[xihaji@linux-01 ~]$ ll
总用量 0
-rw-rw-r--. 1 xihaji xihaji 0 3月  21 04:34 1.txt
[xihaji@linux-01 ~]$ mkdir ceshi ;touch 123
[xihaji@linux-01 ~]$ ll
总用量 0
-rw-rw-r--. 1 xihaji xihaji 0 4月  10 16:07 123
-rw-rw-r--. 1 xihaji xihaji 0 3月  21 04:34 1.txt
drwxrwxr-x. 2 xihaji xihaji 6 4月  10 16:07 ceshi
[xihaji@linux-01 ~]$ 

在第一个终端查看历史命令
[root@linux-01 ceshi]# cat /usr/local/domob/records/xihaji/bash_history 
2019-04-10 16:06:00 ##### xihaji pts/0 (192.168.141.1) #### 19/04/10 16:06:00 exit
2019-04-10 16:06:22 ##### xihaji pts/0 (192.168.141.1) #### 19/04/10 16:06:21 pwd
2019-04-10 16:06:23 ##### xihaji pts/0 (192.168.141.1) #### 19/04/10 16:06:23 ll
2019-04-10 16:07:27 ##### xihaji pts/0 (192.168.141.1) #### 19/04/10 16:07:27 mkdir ceshi ;touch 123
2019-04-10 16:07:29 ##### xihaji pts/0 (192.168.141.1) #### 19/04/10 16:07:29 ll
[root@linux-01 ceshi]# 

2.history 1 | { read x cmd; echo “$cmd”; }

详解:

  • read命令,后面跟的是变量名,可以是1个,也可以是多个,用空格分隔。回车后,输入的字符就是在给这些变量赋值,输入的字符串也需要用空格分隔,如果和上面的变量名一个一个地对应,那么这样就一个一个地赋值了。
  • 如果没有对应呢?通过上面的命令也可以发现,如果值比变量多,它只对应前面的。例如,变量只有x和y,而值是1 2 3,则它把x赋值1,后面的2 3一股脑赋值给最后面的变量y。
  • 管道前面,history 1表示取最后一条命令。管道后面’{ }’内是一整体,相当于一个函数,函数里面可以有多条命令,用分号分割,而且最后一条命令也必须加分号。第一条命令和’{‘之间必须要有空格。

扩展:history 1 | { read x cmd; echo “$cmd”; }

3.正则符号总结

  • . 点代表匹配一个字符
  • * 星号代表匹配星号前面的一个字符存在0次或者多次,.*表示贪婪匹配
  • + 加号表示星号前面的一个字符存在1次或者多次
  • ? 问好表示问号前面的一个字符存在0次或者1次
  • () 小括号表示一个组合
  • {} 大括号表示次数,可以是{2,5}
  • | 表示或者的意思
  • [] 中括号表示匹配中括号中的一个字符
  • ^ 在中括号里表示取反的意思,在中括号外面表示开头
  • $ 表示尾部的意思
  • \ 反斜杠表示转义

4.扩展正则符号

  • 使用以下几个符号的时候请使用egrep或者grep -E 或者在符号前加入转义符
  • *
  • ?
  • ()
  • {}
  • |
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2019-04-10 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 正则三剑客之grep
  • 预习内容
    • 1.grep 过滤指定关键词
      • 1.1 grep选项参数
      • 1.2 正则特殊符号作用
      • 1.3 grep与正则表达式的一起使用
  • 课后总结
    • 1. Linux 系统添加操作记录审计
      • 2.history 1 | { read x cmd; echo “$cmd”; }
        • 3.正则符号总结
          • 4.扩展正则符号
          相关产品与服务
          命令行工具
          腾讯云命令行工具 TCCLI 是管理腾讯云资源的统一工具。使用腾讯云命令行工具,您可以快速调用腾讯云 API 来管理您的腾讯云资源。此外,您还可以基于腾讯云的命令行工具来做自动化和脚本处理,以更多样的方式进行组合和重用。
          领券
          问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档