博客
关于我
Linux利用grep配合正则表达式显示非空注释行内容
阅读量:390 次
发布时间:2019-03-05

本文共 3106 字,大约阅读时间需要 10 分钟。

  • 显示 /etc/inittab 文件中以 ‘#’ 号后跟着一个或多个空白字符开头并且之后是任意个非空白字符的行
  • 查看/etc/inittab的内容
[04:16:42 rooter@C8-3-55 ~]#cat /etc/inittab# inittab is no longer used.## ADDING CONFIGURATION HERE WILL HAVE NO EFFECT ON YOUR SYSTEM.## Ctrl-Alt-Delete is handled by /usr/lib/systemd/system/ctrl-alt-del.target## systemd uses 'targets' instead of runlevels. By default, there are two main targets:## multi-user.target: analogous to runlevel 3# graphical.target: analogous to runlevel 5## To view current default target, run:# systemctl get-default## To set a default target, run:# systemctl set-default TARGET.target
  • 显示#开头的注释行
[04:17:54 rooter@C8-3-55 ~]#cat /etc/inittab | grep ^## inittab is no longer used.## ADDING CONFIGURATION HERE WILL HAVE NO EFFECT ON YOUR SYSTEM.## Ctrl-Alt-Delete is handled by /usr/lib/systemd/system/ctrl-alt-del.target## systemd uses 'targets' instead of runlevels. By default, there are two main targets:## multi-user.target: analogous to runlevel 3# graphical.target: analogous to runlevel 5## To view current default target, run:# systemctl get-default## To set a default target, run:# systemctl set-default TARGET.target
  • 敲错了啥都不显示
    没有加-E不支持正则表达式
[04:19:33 rooter@C8-3-55 ~]#cat /etc/inittab | grep ^#[[:blank:]]+[04:20:28 rooter@C8-3-55 ~]#cat /etc/inittab | grep '^#[[:blank:]]+'
  • 显示#开头,其后是一个或多个空格的行
[04:20:38 rooter@C8-3-55 ~]#cat /etc/inittab | grep -E '^#[[:blank:]]+'# inittab is no longer used.# ADDING CONFIGURATION HERE WILL HAVE NO EFFECT ON YOUR SYSTEM.# Ctrl-Alt-Delete is handled by /usr/lib/systemd/system/ctrl-alt-del.target# systemd uses 'targets' instead of runlevels. By default, there are two main targets:# multi-user.target: analogous to runlevel 3# graphical.target: analogous to runlevel 5# To view current default target, run:# systemctl get-default# To set a default target, run:# systemctl set-default TARGET.target
  • 显示#开头之后是1个或多个空格,之后是非空格的行
[04:21:06 rooter@C8-3-55 ~]#cat /etc/inittab | grep -E '^#[[:blank:]]+[^[:blank:]]+'# inittab is no longer used.# ADDING CONFIGURATION HERE WILL HAVE NO EFFECT ON YOUR SYSTEM.# Ctrl-Alt-Delete is handled by /usr/lib/systemd/system/ctrl-alt-del.target# systemd uses 'targets' instead of runlevels. By default, there are two main targets:# multi-user.target: analogous to runlevel 3# graphical.target: analogous to runlevel 5# To view current default target, run:# systemctl get-default# To set a default target, run:# systemctl set-default TARGET.target
  • 显示#开头,之后是一个或多个空格,然后是非空格及任意字符的行
[04:21:56 rooter@C8-3-55 ~]#cat /etc/inittab | grep -E '^#[[:blank:]]+[^[:blank:]]+.*'# inittab is no longer used.# ADDING CONFIGURATION HERE WILL HAVE NO EFFECT ON YOUR SYSTEM.# Ctrl-Alt-Delete is handled by /usr/lib/systemd/system/ctrl-alt-del.target# systemd uses 'targets' instead of runlevels. By default, there are two main targets:# multi-user.target: analogous to runlevel 3# graphical.target: analogous to runlevel 5# To view current default target, run:# systemctl get-default# To set a default target, run:# systemctl set-default TARGET.target

问题:

  • #号开头之后紧跟着1个以上空格的及任意字符的行,为啥把#后跟空行也过滤掉了?
    空行被过滤掉了

回答:

  • 看起来像#空行,但人家直接#$就结束了!
  • 所以用一个以上blank就把看起来像空行的过滤掉了
    假空行

转载地址:http://eqkzz.baihongyu.com/

你可能感兴趣的文章
MySQL通用优化手册
查看>>
Mysql通过data文件恢复
查看>>
MYSQL遇到Deadlock found when trying to get lock,解决方案
查看>>
MYSQL遇到Deadlock found when trying to get lock,解决方案
查看>>
mysql部署错误
查看>>
MySQL配置信息解读(my.cnf)
查看>>
Mysql配置文件my.ini详解
查看>>
MySQL配置文件深度解析:10个关键参数及优化技巧---强烈要求的福利来咯。
查看>>
Mysql配置表名忽略大小写(SpringBoot连接表时提示不存在,实际是存在的)
查看>>
mysql配置读写分离并在若依框架使用读写分离
查看>>
MySQL里为什么会建议不要使用SELECT *?
查看>>
MySQL里的那些日志们
查看>>
MySQL锁
查看>>
MySQL锁与脏读、不可重复读、幻读详解
查看>>
MySQL锁机制
查看>>
mysql锁机制,主从复制
查看>>
Mysql锁机制,行锁表锁
查看>>
MySQL锁表问题排查
查看>>
Mysql锁(2):表级锁
查看>>
MySQL锁,锁的到底是什么?
查看>>