zoukankan      html  css  js  c++  java
  • vi 替换命令 以及“找不到模式”解决

    转自:https://www.cnblogs.com/zfyouxi/p/5181363.html

    在linux vi编辑工具中使用替换命令操作时,会出现明明有匹配查找模式的数据。却报“找不到模式”问题。

    原因是vi s///替换操作缺省针对行,若要生效,则须要将光标移动到指定行,再使用s///命令就可以。

    若要进行批量替换,则使用%s///命令,比如:

    :%s/192.168.1.8/192.168.20.240/g

    当中g表示全局替换。

    vi替换命令參考:

    http://hi.baidu.com/our_poll/item/bb87c33233af5bbe633afff4

    vi/vim 中能够使用 :s 命令来替换字符串。曾经仅仅会使用一种格式来全文替换,今天发现该命令有非常多种写法(vi 真是强大啊,还有非常多须要学习)。记录几种在此,方便以后查询。
    :s/vivian/sky/ 替换当前行第一个 vivian 为 sky

    :s/vivian/sky/g 替换当前行全部 vivian 为 sky

    :n,$s/vivian/sky/ 替换第 n 行開始到最后一行中每一行的第一个 vivian 为 sky

    :n,$s/vivian/sky/g 替换第 n 行開始到最后一行中每一行全部 vivian 为 sky

    n 为数字。若 n 为 .。表示从当前行開始到最后一行

    :%s/vivian/sky/(等同于 :g/vivian/s//sky/) 替换每一行的第一个 vivian 为 sky

    :%s/vivian/sky/g(等同于 :g/vivian/s//sky/g) 替换每一行中全部 vivian 为 sky

    能够使用 # 作为分隔符,此时中间出现的 / 不会作为分隔符(对于文件夹替换非常实用)

    :s#vivian/#sky/# 替换当前行第一个 vivian/ 为 sky/

    :%s+/oradata/apras/+/user01/apras1+ (使用+ 来 替换 / ): /oradata/apras/替换成/user01/apras1/
    要替换指定行的字符串。仅仅需在s前加上n,m(n到m行就可以)
    * ************************************

    1.:s/vivian/sky/ 替换当前行第一个 vivian 为 sky

    :s/vivian/sky/g 替换当前行全部 vivian 为 sky

    2. :n,$s/vivian/sky/ 替换第 n 行開始到最后一行中每一行的第一个 vivian 为 sky

    :n,$s/vivian/sky/g 替换第 n 行開始到最后一行中每一行全部 vivian 为 sky

    (n 为数字,若 n 为 .,表示从当前行開始到最后一行)

    3. :%s/vivian/sky/(等同于 :g/vivian/s//sky/) 替换每一行的第一个 vivian 为 sky

    :%s/vivian/sky/g(等同于 :g/vivian/s//sky/g) 替换每一行中全部 vivian 为 sky

    4. 能够使用 # 作为分隔符,此时中间出现的 / 不会作为分隔符

    :s#vivian/#sky/# 替换当前行第一个 vivian/ 为 sky/
    5. 删除文本中的^M
    :1,$ /^M//

    问题描写叙述:对于换行,window下用回车换行(0A0D)来表示,linux下是回车(0A)来表示。

    这样,将window上的文件拷到unix上用时,总会有个^M.请写个用在unix下的过滤windows文件的换行符(0D)的shell或c程序。

    · 使用命令:cat filename1 | tr -d “^V^M” >newfile;

    · 使用命令:sed -e “s/^V^M//” filename >outputfilename。需要注意的是在1、2两种方法中。^V和^M指的是Ctrl+V和Ctrl+M。你必需要手工进行输入。而不是粘贴。



    · 在vi中处理:首先使用vi打开文件,然后按ESC键。接着输入命令:%s/^V^M//。

    · :%s/^M$//g

    假设上述方法无用,则正确的解决的方法是:

    · tr -d "r" <src >dest

    · tr -d "5" dest

    · strings A>B

    6. 其他

    利用 :s 命令能够实现字符串的替换。

    详细的使用方法包含:

    :s/str1/str2/ 用字符串 str2 替换行中首次出现的字符串 str1

    :s/str1/str2/g 用字符串 str2 替换行中全部出现的字符串 str1

    :.,$ s/str1/str2/g 用字符串 str2 替换正文当前行到末尾全部出现的字符串 str1

    :1,$ s/str1/str2/g 用字符串 str2 替换正文中全部出现的字符串 str1

    :g/str1/s//str2/g 功能同上

    从上述替换命令能够看到:g 放在命令末尾。表示对搜索字符串的每次出现进行替换;不加 g,表示仅仅对搜索

    字符串的首次出现进行替换;g 放在命令开头,表示对正文中全部包括搜索字符串的行进行替换操作。

    1. 全局替换
    (1) v + G + $ 选定所有,然后输入 :s/原始字符串/目标字符串/
    (2) :%s/原始字符串/目标字符串/

    2. 清除页面中全部行尾的空白符:
    :%s/s+$//

    3. 清除全部空白
    :%s/(s* )+/ /

    4. 去掉全部的//凝视
    :%s!s*//.*!!

    5. 去掉全部的/* */凝视
    :%s!s*/*\_.{-}*/s*! !

    6. 做某些内部数据反复替换
    有些时候我们须要组织一些批量的数据进行命令行的运行,比方我们须要利用前面的数据生成后面的数据,比如这种数据:
    /var/database/aaa.txt
    /var/database/bbb.txt
    /var/database/ccc.txt

    我想变成一个个的指令,比方变成一个个复制命令,拷贝到但前文件夹。那么能够运行:
    :%s/(.*base/)(.*.txt)/cp 12 ./2/

    变成了:
    cp /var/database/aaa.txt ./aaa.txt
    cp /var/database/bbb.txt ./bbb.txt
    cp /var/database/ccc.txt ./ccc.txt

    这里关键是子模式的使用: () 中间的,1 代表第一个找到的子模式,2代表第二个,以此类推。vim里面的()必须转义,跟其它语言不一样


    7. 添加凝视(一个操作应用在多行)
    比方须要添加#或者是//这样的凝视:
    Ctrl + v 定位到開始行。然后选定须要的行,然后运行 I 命令,然后输入 # 或 //,然后按 Esc键两次,就可以把凝视操作应用到全部选定的行。记住选定不能使用v指令,而应该使用Ctrl + v (清除凝视请參考上面的方法)(v是按行选定,Ctrl + v 是依照列选定)

    8. 对齐行
    v 选定须要整齐的行,输入 = 进行归整

    9. 打开多窗体
    在vim中使用 :sp 文件名称 打开行窗体(横),使用 :vsp 文件名称 打开列窗体(竖),使用 :q 关闭当前窗体,使用 :qa 关闭全部窗体,使用 Ctrl + w 在各个窗体中进行切换。


    最大化窗体:Ctrl + w 激活某个窗体,然后 Shitf + - 进行最大化
    改变窗体到指定行高度:Ctrl + w 激活窗体,10(须要变成的行大小数字),Shift + -,运行改变
    添加若干行高度:Ctrl + w 激活窗体,10(须要添加的行大小数字),Shift + +。运行改变

    10. 字符串/变量提示
    在输入内容状态。按 Ctrl + P 则显示全部本页中定义的字符串,假设输入字符串部分内容。然后按 Ctrl + p 则把全部你输入字符串开头的内容显示出来。在输入状态下按 Ctrl + x 能过查看全部有效的其它方式删除操作

    :%s/r//g 删除DOS方式的回车^M
    :%s= *$== 删除行尾空白

    :%s/^(.*)n1/1$/ 删除反复行

    :%s/^.{-}pdf/new.pdf/ 仅仅是删除第一个pdf

    :%s/<!--_.{-}-->// 又是删除多行凝视(咦?为什么要说「又」呢?)

    :g/s*^$/d 删除全部空行 :这个好用有没有人用过还有其它的方法吗?
    :g!/^dd/d 删除不含字符串'dd'的行
    :v/^dd/d 同上 (译释:v == g!,就是不匹配!



    :g/str1/,/str2/d 删除全部第一个含str1到第一个含str2之间的行


    :v/./.,/./-1join 压缩空行
    :g/^$/,/./-j 压缩空行

    ndw 或 ndW 删除光标处開始及其后的 n-1 个字符。


    d0 删至行首。
    d$ 删至行尾。
    ndd 删除当前行及其后 n-1 行。
    x 或 X 删除一个字符。
    Ctrl+u 删除输入方式下所输入的文本。
    ^R 恢复u的操作
    J 把下一行合并到当前行尾
    V 选择一行
    ^V 按下^V后就可以进行矩形的选择了
    aw 选择单词
    iw 内部单词(无空格)
    as 选择句子
    is 选择句子(无空格)
    ap 选择段落
    ip 选择段落(无空格)
    D 删除到行尾
    x,y 删除与复制包括高亮区

    dl 删除当前字符(与x命令功能同样)
    d0 删除到某一行的開始位置
    d^ 删除到某一行的第一个字符位置(不包含空格或TAB字符)
    dw 删除到某个单词的结尾位置
    d3w 删除到第三个单词的结尾位置
    db 删除到某个单词的開始位置
    dW 删除到某个以空格作为分隔符的单词的结尾位置
    dB 删除到某个以空格作为分隔符的单词的開始位置
    d7B 删除到前面7个以空格作为分隔符的单词的開始位置
    d) 删除到某个语句的结尾位置
    d4) 删除到第四个语句的结尾位置
    d( 删除到某个语句的開始位置
    d) 删除到某个段落的结尾位置
    d{ 删除到某个段落的開始位置
    d7{ 删除到当前段落起始位置之前的第7个段落位置
    dd 删除当前行
    d/text 删除从文本中出现“text”中所指定字样的位置,
    一直向前直到下一个该字样所出现的位置(但不包含该字样)之间的内容
    dfc 删除从文本中出现字符“c”的位置,一直向前直到下一个该字符所出现的位置(包含该字符)之间的内容
    dtc 删除当前行直到下一个字符“c”所出现位置之间的内容
    D 删除到某一行的结尾
    d$ 删除到某一行的结尾
    5dd 删除从当前行所開始的5行内容
    dL 删除直到屏幕上最后一行的内容
    dH 删除直到屏幕上第一行的内容
    dG 删除直到工作缓存区结尾的内容
    d1G 删除直到工作缓存区開始的内容今天用了
    4. 去掉全部的//凝视
    :%s!s*//.*!!

    5. 去掉全部的/* */凝视
    :%s!s*/*\_.{-}*/s*! !

  • 相关阅读:
    享元模式(Flyweight)
    策略模式(strategy)
    访问者模式(Visitor)
    适配器模式(Adapter)
    外观模式(Facade)
    代理模式(Proxy)
    ORACLE 表空间扩展方法
    Oracle XML Publisher
    DB.Package procedure Report
    case ... end 语句
  • 原文地址:https://www.cnblogs.com/wang-yaz/p/11014507.html
Copyright © 2011-2022 走看看