I have two columns full of text, and I want to get them side-by-side. For example, I have
abc
def
ghi
and
123
456
789
If you'd like to manually set the register type to say blockwise, use this
:call setreg(0, getreg(0), 'b')
or
:call setreg('*', getreg('*'), 'b')
Useful for pasting a column from a spreadsheet editor.
See :help setreg
and vimtip for details.
Use visual block (ctrl-v
) to cut the letter column. Then move to the first line of the number column. Move to the end and make one space. Then paste the letter column.
This may seem obvious, but if you are pasting from an externally copied buffer it will not work with just visual mode paste. What you can do is first do a normal paste in an empty area and vertical cut/paste using the above method.
If you're on a Mac and can't figure out why the paste is inserting the block in new lines, it's because you're using the system pasteboard.
No problem, just yank/paste with buffers:
letter
bufferletter
bufferMake sure that letter
is not +
as that is the system pasteboard buffer and thus it will have the same effect.
You have:
abc
def
ghi
123
456
789
Move your cursor onto the a
. Then CTRL+V
, and move your cursor to i
. Press y
.
Next, add a space after the 3
character, and press p
.
Done.
I was wondering why "visual block mode" wasn't working for me. The key is to yank (or delete) in visual mode.
I find myself needing to copy some stuff from excel columns having variable lengths. Here's how I do it:
Names
Donald Knuth
Sebastian Thrun
Peter Norvig
Satoshi Nakamoto
Age
100
50
60
45
Let's say you want to put the second column after the first.
Age
Ctrl + v
to enter visual mode5
in 45
y
to yank (or d
to delete)You have now yanked in visual mode.
Paste (in normal mode)
Move to the end of the first line and add more spaces because it's shorter than the second line for example. If you paste a "block" without adding extra spaces, it will overwrite the "run" in Sebastian Thrun.
Now you're on the first line, insert a few spaces after the last character. Make sure you're not in insert mode and hit p
to paste the block. (If you want to paste in insert mode, use ctrl+r "
)