Using VIM as a logfile-viewer

2019-02-08 09:45发布

I'd like to use VIM as a logfile-viewer. Is it possible to reload the current file in a regular time interval (~1s)?

标签: vim logging
3条回答
唯我独甜
2楼-- · 2019-02-08 10:00

use :set autoread

查看更多
我想做一个坏孩纸
3楼-- · 2019-02-08 10:02

I like it short and without a lot of hacking or external scripts. You can run this oneliner from ex (whithin vim) when needed (or put each command in vimrc, for when log-files are opened.)

:set autoread | au CursorHold * checktime | call feedkeys("lh")

(if you would want to jump (nearly) to the end of the file, just use "G" instead of "lh" with feedkeys)

Explanation:

  • autoread: reads the file when changed from the outside (but it doesnt work on its own, there is no internal timer or something like that. It will only read the file when vim does an action, like a command in ex :!
  • CursorHold * checktime: when the cursor isn't moved by the user for the time specified in updatetime (which is 4000 miliseconds by default) checktime is executed, which checks for changes from outside the file
  • call feedkeys("lh"): the cursor is moved once, right and back left. and then nothing happens (... which means, that CursorHold is triggered, which means we have a loop)

To stop the scrolling when using call feedkeys("G"), execute :set noautoread - now vim will tell, that the file was change ans ask if one wants to read the changes or not)

I like the idea to watch logfiles in vim (instead of tail -f), e.g. when you are working in an ssh session without screen/tmux. Additionally you can copy directly from the logfile, if needed, or save the output directly or ... whatever you can do with vim :)

*from this answer (refering to an answer by PhanHaiQuang and a comment by flukus)

查看更多
一纸荒年 Trace。
4楼-- · 2019-02-08 10:04

See this VIM tip. It offers tailing (like tail -f) together with log line numbering

查看更多
登录 后发表回答