To wyszukiwanie przesuwa 40 znaków (ale nie bajtów) do przodu:
/\_.\{40}/e
wyszukując dokładnie 40 znaków \{40}
dowolnego rodzaju (w tym newline ( \_.
) i umieszczając kursor na końcu wyszukiwania ( /e
). Zobacz: http://vimregex.com/#Non-Greedy , :help search-offset
i:help \_
Zobacz także :h 23.4
edycję binarną.
Aktualizacja: Na podstawie tej odpowiedzi, oto funkcja, która przeskakuje do przesunięcia bajtu:
let s:last_jump_bytes = 0
function! JumpTo(byte_nr)
let crt_byte = line2byte(line('.')) + col('.')
if (a:byte_nr == 0)
let dst_byte = crt_byte + s:last_jump_bytes
else
let dst_byte = crt_byte + a:byte_nr
let s:last_jump_bytes = a:byte_nr
endif
let dst_line = byte2line(dst_byte)
let dst_col = dst_byte -line2byte(dst_line)
"remove next line if you don't want to record this for `Ctrl-O`
execute "normal " . dst_line . "G"
call setpos('.', [0, dst_line, dst_col])
endfunction
command! -nargs=1 JumpToOffset :call JumpTo(<f-args>)
" silly mapping to Ctrl-C (demo)
nnoremap <expr> <silent> <c-c> ":<c-u>call JumpTo(" . v:count . ")<cr>"
Można użyć w następujący sposób:
:JumpToOffset 400
lub wpisując mapowane mapowanie klawiatury z liczbą:
40CTRL-C
Jeśli nie użyjesz licznika, poprzedni numer zostanie ponownie użyty. Więc możesz zrobić: 40CTRL-C CTRL-C CTRL-C 30CTRL-C CTRL-C
przeskoczyć 40, 40, 40, 30, 30 bajtów itp.
Naciśnij, Ctrl-O
aby przeskoczyć do tyłu (patrz komentarze wewnątrz funkcji).
Xl
(gdzieX
jest liczba znaków) lub liczby znaków, a następnie strzałki w prawo.