首页 \ 问答 \ 在Vim中如何切换命令和插入模式?(How do I switch between command and insert mode in Vim?)

在Vim中如何切换命令和插入模式?(How do I switch between command and insert mode in Vim?)

我刚开始使用Vim作为IDE。 我现在使用它作为测试编辑器,所以我不必经常去命令模式。 但是,由于我在Java程序中,我必须去命令模式来创建文件,编译/运行它等等

问题是:我需要一种很好的方式在两种模式之间切换。

我在网上查看,它表示<Esc>键应该这样做,但这对我来说并不奏效(也许这不是gVim吗?我不知道为什么)

我每次都要按CTRL O进入命令模式; 逃脱密钥从该模式工作...它使我回到插入模式。 但是,在命令模式和插入模式之间是否有更好的或更简单的切换方式?


I just started using Vim as an IDE. I was using it as a test editor for a while now, so I didn't have to go to command mode very often. But, since I program in Java, I have to go to command mode to make the file, compile/run it... etc.

The problem is: I need a good way to switch between the two modes.

I looked online and it says that the <Esc> key is supposed to do that, but that doesn't work for me (maybe it's not for gVim? I don't know why.)

I have to press CTRLO every time to go to command mode; the escape key works from that mode... it brings me back to insert mode. But is there a better, or easier, way of switching between command mode and insert mode?


原文:https://stackoverflow.com/questions/13178874
更新时间:2023-05-24 14:05

最满意答案

UPDATE mytable
SET myfield = SUBSTRING(myfield, 1, LENGTH(myfield)-4) ;

如果你想在截断之前检查字段是否以'.php'结尾,你可以添加这个条件:

UPDATE mytable
SET myfield = SUBSTRING(myfield, 1, LENGTH(myfield)-4)
WHERE RIGHT(myfield, 4) = '.php' ;

哦,还有LEFT()可以用来代替SUBSTRING()

CHAR_LENGTH()应该用来代替LENGTH()因为它是多字节安全的(而LENGTH()不是):

UPDATE mytable
SET myfield = LEFT(myfield, CHAR_LENGTH(myfield)-4)
WHERE RIGHT(myfield, 4) = '.php' ;

UPDATE mytable
SET myfield = SUBSTRING(myfield, 1, LENGTH(myfield)-4) ;

If you want to also check whether the field ends with '.php' before truncating, you can add this condition:

UPDATE mytable
SET myfield = SUBSTRING(myfield, 1, LENGTH(myfield)-4)
WHERE RIGHT(myfield, 4) = '.php' ;

Oh, there's also LEFT() which can be used instead of SUBSTRING() as well

And CHAR_LENGTH() should be used instead of LENGTH() as it is multi-byte safe (while LENGTH() is not):

UPDATE mytable
SET myfield = LEFT(myfield, CHAR_LENGTH(myfield)-4)
WHERE RIGHT(myfield, 4) = '.php' ;

相关问答

更多

相关文章

更多

最新问答

更多
  • 获取MVC 4使用的DisplayMode后缀(Get the DisplayMode Suffix being used by MVC 4)
  • 如何通过引用返回对象?(How is returning an object by reference possible?)
  • 矩阵如何存储在内存中?(How are matrices stored in memory?)
  • 每个请求的Java新会话?(Java New Session For Each Request?)
  • css:浮动div中重叠的标题h1(css: overlapping headlines h1 in floated divs)
  • 无论图像如何,Caffe预测同一类(Caffe predicts same class regardless of image)
  • xcode语法颜色编码解释?(xcode syntax color coding explained?)
  • 在Access 2010 Runtime中使用Office 2000校对工具(Use Office 2000 proofing tools in Access 2010 Runtime)
  • 从单独的Web主机将图像传输到服务器上(Getting images onto server from separate web host)
  • 从旧版本复制文件并保留它们(旧/新版本)(Copy a file from old revision and keep both of them (old / new revision))
  • 西安哪有PLC可控制编程的培训
  • 在Entity Framework中选择基类(Select base class in Entity Framework)
  • 在Android中出现错误“数据集和渲染器应该不为null,并且应该具有相同数量的系列”(Error “Dataset and renderer should be not null and should have the same number of series” in Android)
  • 电脑二级VF有什么用
  • Datamapper Ruby如何添加Hook方法(Datamapper Ruby How to add Hook Method)
  • 金华英语角.
  • 手机软件如何制作
  • 用于Android webview中图像保存的上下文菜单(Context Menu for Image Saving in an Android webview)
  • 注意:未定义的偏移量:PHP(Notice: Undefined offset: PHP)
  • 如何读R中的大数据集[复制](How to read large dataset in R [duplicate])
  • Unity 5 Heighmap与地形宽度/地形长度的分辨率关系?(Unity 5 Heighmap Resolution relationship to terrain width / terrain length?)
  • 如何通知PipedOutputStream线程写入最后一个字节的PipedInputStream线程?(How to notify PipedInputStream thread that PipedOutputStream thread has written last byte?)
  • python的访问器方法有哪些
  • DeviceNetworkInformation:哪个是哪个?(DeviceNetworkInformation: Which is which?)
  • 在Ruby中对组合进行排序(Sorting a combination in Ruby)
  • 网站开发的流程?
  • 使用Zend Framework 2中的JOIN sql检索数据(Retrieve data using JOIN sql in Zend Framework 2)
  • 条带格式类型格式模式编号无法正常工作(Stripes format type format pattern number not working properly)
  • 透明度错误IE11(Transparency bug IE11)
  • linux的基本操作命令。。。