博客
关于我
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常见错误分析与解决方法总结
查看>>
mysql并发死锁案例
查看>>
MySQL底层概述—1.InnoDB内存结构
查看>>
MySQL底层概述—2.InnoDB磁盘结构
查看>>
MySQL底层概述—3.InnoDB线程模型
查看>>
MySQL底层概述—4.InnoDB数据文件
查看>>
MySQL底层概述—5.InnoDB参数优化
查看>>
MySQL底层概述—6.索引原理
查看>>
MySQL底层概述—7.优化原则及慢查询
查看>>
MySQL底层概述—8.JOIN排序索引优化
查看>>
MySQL底层概述—9.ACID与事务
查看>>
Mysql建立中英文全文索引(mysql5.7以上)
查看>>
mysql建立索引的几大原则
查看>>
Mysql建表中的 “FEDERATED 引擎连接失败 - Server Name Doesn‘t Exist“ 解决方法
查看>>
MySQL开源工具推荐,有了它我卸了珍藏多年Nactive!
查看>>
MySQL异步操作在C++中的应用
查看>>
MySQL引擎讲解
查看>>
Mysql当前列的值等于上一行的值累加前一列的值
查看>>
MySQL当查询的时候有多个结果,但需要返回一条的情况用GROUP_CONCAT拼接
查看>>