• vim删除#开头的行和正则表达式笔记


    问题:httpd.conf配置文件中存在很多以#号开头的行,请使用vim相关指令删除#开头的行.

     

    更新:最终答案为:

    :g/ *#.*/d

    以下全部为探索过程!

    答案:    :1,$s/^#.*//g 或 :1,$s/^#.*//  (不用g也行)

    但这样只会把第一个字符是#的行删掉,不会把空格开头,但#为首字符的字段删掉,所以下面是改进版:

    :1,$s/ *#.*//

    效果:

     但此时仍有很多空行,下面删去空行:

    :g/^s*$/d


    简单解释一下:

    g :全区命令
    / :分隔符
    ^s*$ :匹配空行,其中^表示行首,s表示空字符,包括空格和制表符,*重复0到n个前面的字符,$表示行尾。连起来就是匹配只有空字符的行,也就是空行。
    /d :删除该行

     最终效果:

     

    笔记:

    1,$:对所有行生效.(从第一行到最后一行($)都生效)

    s/x/y/:将x替换为y.

    ^#:开头为#的.

    .*:和后面若干个字符.

    g:(global)全局的.例如,s/x/y/只会将一行中第一个x替换为y,但s/x/y/g会将一行中所有的x替换为y.

    ^:[反向选择] 或 [定位在行首],在[]内代表反向选择,在[]外代表定位在行首.

    $:定位在行尾.

    .(小数点):代表[一定有一个任意字符].

    举例: #grep -n 'g..d' xx.txt

    意义:从xx.txt中找出有开头是g,结尾时d,g和d中间必有两个字符的行.

    *(星号):代表[重复前一个字符,0到无穷多次]

    举例:[xx*] 第一个x必须有,第二个x可有可无,x*是一起的.

     

  • 相关阅读:
    预习十进制数的表示 & 非数值数据的编码表示 & 数据的宽度和储存 & 数据校验码*
    预习原码补码移码
    C语言||作业01 结构:通讯录
    C语言寒假大作战04
    C语言寒假大作战03
    C语言寒假大作战02
    C语言寒假大作战01
    C语言||作业01 结构:通讯录
    C语言寒假大作战04
    C语言寒假大作战03
  • 原文地址:https://www.cnblogs.com/Ravenzzz/p/9746244.html
Copyright © 2020-2023  润新知