zoukankan      html  css  js  c++  java
  • vi下的查找替换命令

    1、查找

    查找命令

    /pattern:向下查找匹配的字符

    ?pattern:向上查找匹配的字符

    其中pattern是需要匹配的字符串,例如:

    /cd      #全文查找cd
    / cd <Enter>    #查找<space>cd<space>的字符串(注意空格)

      pattern还可以使用正则表达式,“/”为转义字符。

    /^cd    #查找以cd开始的行 
    /cd$    #查找以cd结束的行 
    //^cd<Enter>    #查找^cd的字符串

    二、替换 

    基本替换 

    :s/sun/moon/         #替换当前行第一个sun为moon
    :s/sun/moon/g        #替换当前行所有sun为moon
    :n,$s/sun/moon/      #替换第 n 行开始到最后一行中每一行的第一个sun为moon
    :n,$s/sun/moon/g     #替换第 n 行开始到最后一行中每一行所有sun为moon
    (n为数字,如果n为 . ,表示从当前行开始到最后一行)  
    :%s/sun/moon/        #(等同于:g/sun/s//moon/)替换每一行的第一个sun为moon
    :%s/sun/moon/g       #(等同于:g/sun/s//moon/g)替换每一行中所有sun为moon

     如果替换字段包含/,可以使用#或+作为分隔符

    :s#sun/#moon/#                      替换当前行第一个sun/为moon/
    :%s+/usr/local/+/var/tmp/+      (使用+替换/):/usr/local/替换成/var/tmp/

    删除文本中的^M 

    windows下的文件如果拷贝到类UNIX系统上,文件结尾总是会有“^M”出现,为了解决这种问题,可以使用以下方法:
    使用命令:cat file | tr -d “^V^M” > newfile 
    使用命令:sed -e “s/^V^M//” file > newfile 
    其中^V和^M指的是Ctrl+V和Ctrl+M。但是你必须要手工进行输入,而不是粘贴。 
    在vi中处理:首先使用vi打开文件,然后按ESC键,接着输入命令:

    :%s/^V^M//
    :%s/^M$//g

    如果上述方法无用,则解决办法是:

    tr -d “/r” < src >dest
    tr -d “/015″ dest
    
    strings A>B

     

    三、简单的vim正则表达式规则 

    在vim中有四种表达式规则: 
    magic(/m):除了$.*^之外其他元字符都要加反斜杠 
    nomagic(/M):除了$^之外其他元字符都要加反斜杠 
    /v(即 very magic 之意):任何元字符都不用加反斜杠 
    /V(即 very nomagic 之意):任何元字符都必须加反斜杠 

    vim默认使用magic设置,这个设置也可以在正则表达式中通过 /m /M /v /V开关临时切换。例如:

    //m.*          # 查找任意字符串
    //M.*          # 查找字符串 .* (点号后面跟个星号)
    
    //v(a.c){3}$   # 查找行尾的abcaccadc
    //m(a.c){3}$   # 查找行尾的(abc){3}
    //M(a.c){3}$   # 查找行尾的(a.c){3}
    //V(a.c){3}$   # 查找任意位置的(a.c){3}$

    推荐使用默认的magic设置,在这种情况下,常用的匹配有:

    //<sun          #查找以sun开始的字符串 
    /moon/>         #查找以moon结束的字符串 
    
    $               #匹配一行的结束
    ^               #匹配一行的开始
    /<              #匹配一个单词的开始,例如//<abc<Enter>:查找以abc开始的字符串
    />              #匹配一个单词的结束,例如/abc/><Enter>:查找以abc结束的字符串 
     
    *               #匹配0或多次
    /+              #匹配1或多次
    /=              #匹配0或1次
     
    .               #匹配除换行符以外任意字符    
    /a              #匹配一个字符
    /d              #匹配任一数字      
    /u              #匹配任一大写字母
    
    []              #匹配范围,如t[abcd]s 匹配tas tbs tcs tds
    /{}             #重复次数,如a/{3,5} 匹配3~5个a
    /( /)           #定义重复组,如a/(xy/)b 匹配ab axyb axyxyb axyxyxyb ...
    /|              #或,如:for/|bar 表示匹配for或者bar
    
    /%20c           #匹配第20列
    /%20l           #匹配第20行
  • 相关阅读:
    BestCoder Round #29 1003 (hdu 5172) GTY's gay friends [线段树 判不同 预处理 好题]
    POJ 1182 食物链 [并查集 带权并查集 开拓思路]
    Codeforces Round #288 (Div. 2) E. Arthur and Brackets [dp 贪心]
    Codeforces Round #287 (Div. 2) E. Breaking Good [Dijkstra 最短路 优先队列]
    Codeforces Round #287 (Div. 2) D. The Maths Lecture [数位dp]
    NOJ1203 最多约数问题 [搜索 数论]
    poj1426
    POJ 1502 MPI Maelstrom [最短路 Dijkstra]
    POJ 2785 4 Values whose Sum is 0 [二分]
    浅析group by,having count()
  • 原文地址:https://www.cnblogs.com/cdinc/p/5695916.html
Copyright © 2011-2022 走看看