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

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

在处理/etc/inittab文件时,如果使用了grep命令来筛选注释行,可能会遇到一些空行被误选中的情况。这种问题通常是由于正则表达式不够严格,导致它匹配了看起来像是空行的内容。

为了解决这个问题,可以修改正则表达式,确保只匹配那些有实际内容的注释行。以下是详细的解决方案:

  • 分析当前正则表达式:原来的正则表达式^#[[:blank:]]+[^[:blank:]]+.*用于匹配以#开头,后面跟着一个或多个空格,然后是至少一个非空格字符,后面可以有任意内容的行。然而,这个表达式也会匹配那些仅有#和空格,或者是完全空白的行。

  • 修改正则表达式:为了避免匹配空行,可以修改正则表达式,确保在#后面必须有至少一个空格,然后至少有一个非空格字符。例如,使用^#[[:blank:]]+[^[:blank:]]+.*),这样就能排除掉那些仅有#和空格,或者是完全空白的行。

  • 测试修改后的正则表达式:在终端中执行cat /etc/inittab | grep -E '^#[[:blank:]]+[^[:blank:]]+.*),确认其是否正确筛选出有内容的注释行,而不会误处理空行。

  • 处理特殊情况:如果发现某些行在#后面有空格,但后面没有其他字符,可以考虑使用^#[[:blank:]]+[^[:blank:]]*,这样可以匹配至少一个空格后有零个或多个非空格字符的行,但仍需确认是否符合实际需求。

  • 通过以上步骤,可以确保grep命令正确筛选出有内容的注释行,避免误处理空行。

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

    你可能感兴趣的文章
    Oracle 并行原理与示例总结
    查看>>
    oracle 并集 时间_Oracle集合运算符 交集 并集 差集
    查看>>
    Oracle 序列sequence 开始于某个值(10)执行完nextval 发现查出的值比10还小的解释
    查看>>
    oracle 执行一条查询语句,把数据加载到页面或者前台发生的事情
    查看>>
    oracle 批量生成建同义词语句和付权语句
    查看>>
    oracle 抓包工具,shell 安装oracle和pfring(抓包) 及自动环境配置
    查看>>
    Oracle 拆分以逗号分隔的字符串为多行数据
    查看>>
    Oracle 排序中使用nulls first 或者nulls last 语法
    查看>>
    oracle 插入date日期类型的数据、插入从表中查出的数据,使用表中的默认数据
    查看>>
    Oracle 操作笔记
    查看>>
    oracle 数据库 安装 和优化
    查看>>
    oracle 数据库dg搭建规范1
    查看>>
    Oracle 数据库常用SQL语句(1)
    查看>>
    Oracle 数据库特殊查询总结
    查看>>
    Oracle 数据类型
    查看>>
    oracle 数据迁移 怎么保证 和原表的数据顺序一致_一个比传统数据库快 1001000 倍的数据库,来看一看?...
    查看>>
    oracle 时间函数
    查看>>
    oracle 时间转化函数及常见函数 .
    查看>>
    Oracle 权限(grant、revoke)
    查看>>
    oracle 查询clob
    查看>>