上位N行を繰り返すことができる、以下のようなページャープログラム


15

less表示されたすべてのページでプログラムに最初の行(または最初の2行)を繰り返す方法はありますか?

これを行うことができる他のページャープログラムはありますか?

これは、データベーステーブルの閲覧のためのキラーアプリも思うだろうmysqlか、psqlまたはgqlplus...

アイデアがわからない方は、このページの下部にあるスクリーンショットをご覧ください。ヘッダー行+水平アスキーバーを繰り返します。


ああ、フリーズペインポイントのように、それよりも少ない拡張機能を要求します。たとえば、-freeze-pane 10,2は、1行の列ヘッダーと10列の行ヘッダーを保持します。水平および垂直スクロールは、それぞれ行と列のヘッダーを保持します。それは本当にpsqlのページャに使用する冷却されるだろう(merlinmoncure.blogspot.com/2007/10/better-psql-with-less.html)
ギュンターSchadow

回答:


12

Vimを使用した解決策があります。

最初に、ほとんどの作業を行うVimマクロが必要です。保存する場所は~/.vim/plugin/less.vim次のとおりです。

" :Less
" turn vim into a pager for psql aligned results 
fun! Less()
  set nocompatible
  set nowrap
  set scrollopt=hor
  set scrollbind
  set number
  execute 'above split'
  " resize upper window to one line; two lines are not needed because vim adds separating line
  execute 'resize 1'
  " switch to lower window and scroll 2 lines down 
  wincmd j
  execute 'norm! 2^E'
  " hide statusline in lower window
  set laststatus=0
  " hide contents of upper statusline. editor note: do not remove trailing spaces in next line!
  set statusline=\  
  " arrows do scrolling instead of moving
  nmap ^[OC zL
  nmap ^[OB ^E
  nmap ^[OD zH
  nmap ^[OA ^Y
  nmap <Space> <PageDown>
  " faster quit (I tend to forget about the upper panel)
  nmap q :qa^M
  nmap Q :qa^M
endfun
command! -nargs=0 Less call Less()

次に、ページャーをエミュレートするには、vimを呼び出して次のようにします。

  • 標準入力を読む
  • ただし、コマンドラインで引数が指定されている場合は、そこにあるものをすべて読み取ります。
  • 読み取り専用モードで動作します
  • すべての初期化スクリプトをスキップしますが、代わりに上記で定義したLessマクロを実行します

これをヘルパースクリプトとしてまとめます~/bin/vimpager

#!/bin/bash
what=-
test "$@" && what="$@"
exec vim -u NONE -R -S ~/.vim/plugin/less.vim -c Less $what

第三に、環境変数$ PAGERをオーバーライドする必要がありますが、これはpsql専用です(これをmyに追加します~/.bash_aliases)。

if which vimpager &>/dev/null; then
  alias psql='PAGER=vimpager psql';
fi

これは素敵です、私はそれを試しました。これらの行番号の代わりに、行ヘッダーも追加できると便利です。
ギュンターシャドー

4

Emacs / XEmacsでSQLモードを試しましたか?

確かに、moreまたはのように使用するのは簡単ではありませんlessが、縦横に結果をスクロールしながらヘッダー行を残して、あなたが求めていることを行います。


おかげで、私はEmacsを知らないが、それは面白そうだ。最終的にはシェルスクリプトが必要になります:emacsを起動し、そこでpsqlを実行し(指定されたconn。paramsを使用)、sqlモードを有効にし、必要な処理を実行します(画面サイズより大きいクエリ結果がある場合は常に上位2行をフリーズします) 。それについてのヒントはありますか?
filiprem

3

これは受け入れられた答えから非常に大きく借りていますが、追加します...

  • より高速なスクロール
  • 誤ってヘッダーにスクロールできない
  • 構文の強調表示(一部のクレジットはここにあります
    • 正/負の数、日付、時刻NULL、、真/偽(およびT / F、Y / N、はい/いいえ)
    • 行番号(パイプ文字の前にある場合)。
  • ヘルプテキスト
  • Git for Windowsに含まれているVimのサポート
  • stdinバッファーが変更された場合にビューを更新すると脅迫しないでください

を使用しないので、特定の出力のために一部を調整する必要がある場合がありますpsql。私の目的のためにヘルパー関数も少し異なりますが、それらは受け入れられた答えのものと似ています。

サンプル入力

  | ID |   First   |     Last     | Member | Balance |
--+----+-----------+--------------+--------+---------+
 1|  4 | Tom       | Hanks        | False  |    0.00 |
 2| 12 | Susan     | Patterson    | True   |   10.00 |
 3| 23 | Harriet   | Langford-Wat | False  |    0.00 |
 4|  8 | Jerry     |     NULL     | True   | -382.94 |
[… More rows …]
10| 87 | Horace    | Weaver       | False  |   47.52 |

コード

" :HeadPager
" Turn vim into a pager with a header row
" Adapted from /unix//a/27840/143088
fun! HeadPager()
    " If you didn't get three lines, shortcut out
    if line('$') < 3
        set nocompatible
        nmap <silent> q :qa!<c-M>
        nmap <silent> Q :qa!<c-M>
        return
    endif

    set noswapfile
    set nocompatible
    set nowrap
    set scrollopt=hor
    set scrollbind

    " Hide statusline in lower window
    set laststatus=0
    " Explain mapped chars in status line.
    set statusline=\ \ \ Q\ to\ quit\.\ Arrows\ or\ mousewheel\ to\ scroll\.\ \(Vim\ commands\ work\,\ too\.\)

    " Delete/copy header lines
    silent execute '1,2d'

    " Split screen with new buffer (opens at top)
    execute 'new'

    " Switch to upper split
    wincmd k

    " Paste the header over the blank line
    execute 'norm! Vp'

    " Header highlighting
    syn match Pipe "|"
    hi def Pipe ctermfg=blue
    syn match Any /[^|]\+/
    hi def Any ctermfg=yellow

    " Switch back to lower split for scrolling
    wincmd j

    " Set lower split height to maximum
    execute "norm! \<c-W>_"

    " Syntax highlighting
    syn cluster CellContents contains=None
    syn match Pipe "|" contained nextgroup=@CellContents skipwhite
    hi def Pipe ctermfg=blue

    " Start with newline or |. End right before next | or EOL
    syn region Cell start=/\v(^|\|)\s*/ end=/\v(\||$)\@=/ contains=LineNumber,Pipe

    syn match NumPos /\v\+?\d+(,?\d{3})*\.?\d*\ze *(\||$)\@=/ contained
    syn match NumNeg   /\v-\d+(,?\d{3})*\.?\d*\ze *(\||$)\@=/ contained
    syn match NumZero         /\v[+-]?0+\.?0*\ze *(\||$)\@=/  contained
    hi def NumPos ctermfg=cyan
    hi def NumNeg ctermfg=red
    hi def NumZero ctermfg=NONE
    syn cluster CellContents add=NumPos,NumNeg,NumZero

    syn match DateVal /\v\d{4}-\d{2}-\d{2}/ contained nextgroup=TimeVal skipwhite
    syn match TimeVal /\v\d{1,2}:\d{2}(:\d{2})?(\.\d+)?(Z| ?\c[AP]M)?\ze *(\||$)\@=/ contained
    hi def DateVal ctermfg=magenta
    hi def TimeVal ctermfg=magenta
    syn cluster CellContents add=DateVal,TimeVal

    syn match TrueVal /\v\c(t(rue)?|y(es)?)\ze *(\||$)\@=/ contained
    syn match FalseVal /\v\c(f(alse)?|no?)\ze *(\||$)\@=/ contained
    hi def TrueVal ctermfg=green
    hi def FalseVal ctermfg=red
    syn match NullVal /\v\cnull?\ze *(\||$)\@=/ contained
    hi def NullVal ctermbg=gray ctermfg=black
    syn cluster CellContents add=TrueVal,FalseVal,NullVal

    syn match LineNumber /^ *\d\+/ contained
    hi def LineNumber ctermfg=yellow

    " Arrows do scrolling instead of moving
    nmap <silent> <Up> 3<c-Y>
    nmap <silent> <Down> 3<c-E>
    nmap <silent> <Left> zH
    nmap <silent> <Right> zL
    nmap <Space> <PageDown>
    " Faster quit (I tend to forget about the upper panel)
    nmap <silent> q :qa!<c-M>
    nmap <silent> Q :qa!<c-M>

    " Ignore external updates to the buffer
    autocmd! FileChangedShell */fd/*
    autocmd! FileChangedRO */fd/*
endfun
command! -nargs=0 HeadPager call HeadPager()

2

以下で複数の「リージョン」を使用できますscreen

$ cat screenrc.sql
escape ^aa  # adjust as needed
bind q quit # to quickly exit
screen 0 less ${FILE}
screen 1 less ${FILE}
split  # create two regions
focus top # starting with the top region
resize 4  # make it four lines (one for screen line, one for less prompt)
select 0  # display window 0
focus bottom  # in the bottom region
select 1  # display window 1 and focus here

次に、$ FILE環境変数を設定するだけです。

$ FILE=$HOME/.bash_profile screen -mc screenrc.sql

1
これはほとんど私が望んでいたものですが、(a)上部のウィンドウは右にスクロールしないため、幅の広いテーブルには役に立たない
filiprem

「幅の広いテーブルには役に立たない」という意味がわかりません。screenは、端末のサイズまで拡大できます(fitscreenコマンドを実行しない場合)。上部をスクロールさせたくないと思っていました。自分でテストしたとき、両方のウィンドウがスクロールするはずです。上部は2行(1-2、3-4、5-6など)をスクロールし、下部は必要に応じてスクロールします。あなたが見ている行動は何ですか/
Arcege

0

「forward」の前に数字を追加すると、完全な長さではなく、N行スクロールします。ターミナルウィンドウが40行の場合は、38f38行のみのスクロールを開始し、最後の「ページ」から最後の2行を残して入力します。マンページから:

   SPACE or ^V or f or ^F
          Scroll forward N  lines,  default  one  window  (see  option  -z
          below).   If  N  is  more  than  the screen size, only the final
          screenful is displayed.  Warning: some systems use ^V as a  spe‐
          cial literalization character.

   z      Like  SPACE,  but  if  N is specified, it becomes the new window
          size.

   b or ^B or ESC-v
          Scroll backward N lines,  default  one  window  (see  option  -z
          below).   If  N  is  more  than  the screen size, only the final
          screenful is displayed.

1
最後の N行ではなく、最初の行を保持する必要があります。Googleスプレッドシートの「上位N行を固定」として。
filiprem

あ、ごめんなさい。それを行うユーティリティがあるかどうかはわかりません。次に、私が提案するのは:screenまたはtmuxを使用して2つのペインを作成し、最初のペインのサイズを2行(resize 2)に変更してからless、2番目のペインでを実行しless、正常に実行します。特定の.screenrcファイルを使用して、これをスクリプトとして設定できます。別の回答をご覧ください。
アルケージュ
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.