V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
mongodb
V2EX  ›  Vim

这样的一个操作在VI里该怎么实现

  •  
  •   mongodb · 2013-12-21 13:30:20 +08:00 · 3670 次点击
    这是一个创建于 3991 天前的主题,其中的信息可能已经有所发展或是发生改变。
    编辑一个文件

    形如
    BEGIN

    keyqwertyuiopsdfghjkldfghjkfs
    sdfghjkldfghjkdfghjkl;
    dfghjkdfghjklfghjkl
    sdfghjkl;asdfghjklasdfghjk
    COMMIT
    UPDATE `xxx` set xxxxx

    BEGIN

    keyqwertyuiopsdfghjkldfghjkfs
    sdfghjkldfghjkdfghjkl;
    dfghjkdfghjklfghjkl
    sdfghjkl;asdfghjklasdfghjk
    COMMIT
    UPDATE `xxx` set xxxxx

    BEGIN

    keyqwertyuiopsdfghjkldfghjkfs
    sdfghjkldfghjkdfghjkl;
    dfghjkdfghjklfghjkl
    sdfghjkl;asdfghjklasdfghjk
    COMMIT
    UPDATE `xxx` set xxxxx



    我想删掉其中从BEGIN到COMMIT结束的这个区块
    只保留下各种sql语句

    一开始我想只grep出sql语句到另外的文件,但因为这些语句包含了值后太乱,跨行的,转折的,还有一些错误需要手工修正,只能反过来,把所有从BEGIN到COMMIT的区块都删除。但居然尝试了半天没弄起来,求高手给个例子示范。
    6 条回复    1970-01-01 08:00:00 +08:00
    lyoe
        1
    lyoe  
       2013-12-21 13:34:25 +08:00
    :%s/BEGIN\_.\+COMMIT//g
    lyoe
        2
    lyoe  
       2013-12-21 13:40:29 +08:00
    %s/BEGIN\_[^\(BEGIN\)]\+COMMIT//g
    xcatliu
        3
    xcatliu  
       2013-12-21 18:40:57 +08:00
    用宏吧
    q1/BEGIN<enter><shift-v>/COMMIT<enter>d<esc>q
    1000q
    xcatliu
        4
    xcatliu  
       2013-12-21 18:41:33 +08:00
    1000@1
    maga
        5
    maga  
       2013-12-23 15:25:40 +08:00
    :v/UPDATE/d
    gongcheng
        6
    gongcheng  
       2013-12-23 18:41:02 +08:00
    二楼是正解。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2911 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 25ms · UTC 14:31 · PVG 22:31 · LAX 06:31 · JFK 09:31
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.