VimSum provides a collection of vim commands that perform basic arithmetic on visually selected numbers in neovim or vim.
The arithmetic operations can be used on columns of numbers by selecting them in visual mode.
The routines also can operate on mixed number/word paragraphs (only operating on numbers).
The format of numbers in text may also be adjusted using this plugin, which allows easily
switching between scientific notation and decimal representations. See the VisMult
example.
Common use cases:
Requirements:
Ensure the pynvim python package is installed:
pip install pynvim
If using vim-plug add the following to
.vimrc
.
Plug 'https://github.com/wgurecky/vimSum.git', { 'do' : ':UpdateRemotePlugins' }
Using vimSum with vim8 requires a remote plugin compatibility shim provided by the nvim-yarp plugin:
Plug 'https://github.com/wgurecky/vimSum.git'
Plug 'roxma/nvim-yarp'
Plug 'roxma/vim-hug-neovim-rpc'
Invoke one of the commands below.
Ex: :'<, '>VisMath(2*exp(x), 2f)
Return the sum of all visually selected numbers.
The result is stored in the "@0"
register, so you can paste
the result via "0p
Identical to VisSum
but will compute the mean of
all visually selected numbers.
Multiply all visually selected number by a constant. Format
may be specified as an optional second argument. ex: 4e
for 4
digit decimal sci notation. 2f
for two decimal floating str format.
Example use:
:VisMult(2.0, 2f)
will multiply all selected values by 2.0, format the result to include 2 digits trailing the decimal and change the current buffer in-place.
For just changing the format from decimal representation to scientific; select a block of text in visual mode and then run:
:VisMult(1.0, 5e)
Evaluate any simple mathematical expression of a single variable
denoted by a character
enclosed in parenthesis: (x)
. Values from the visually selected text will be
injected into the formula and the completed expression will be evaluated. ex::
:VisMath(0.5*cos(x)+2.0*exp(x), 4e)
Note:
If using whitespace in a formula string make sure to use an escape char before:
ex: VisMath(0.5*cos(x)\ +\ exp(x), 4e)
It might be useful to create the following, or similar, aliases to the above functions in the vimrc:
" aliases
xnoremap <leader>s :VisSum
xnoremap <leader>a :VisMean
cnoreabbrev vm VisMult
cnoreabbrev ve VisMath
" set verbosity
let g:vimSumVerbose = 1