**注:スーパーユーザーに同じ質問をしましたが、答えを受け取りませんでした。私はこれがこの特定の問題のより良いフォーラムであることに気づきました。 *
kshシェルでは、削除キーが正しく機能しないコマンドラインから。削除キーを押すと〜が表示されます。
私がすることができます:
- バインディング機能「カーソル位置の文字を削除してください」 キーボードボタンを削除するには? (Control-Dは削除ボタンが機能すると予想されたように機能し、エイリアスを使用しようとすると失敗し、おそらく無実だったでしょう。)
- バインディング機能行の最初の行に移動するホームキーボードボタンで? (コントロールAは今これを行いますが、ホームでやりたいです。)
- バインディング機能行末に移動「をキーボード終了ボタンに設定しますか?(コントロールEは今これを行いますが、終了したいです。)
最終(?)更新
役に立つことがわかりましたが、その理由がわかりません。これは働きます:
bind '^[[3'=prefix-2
bind '^[[3~'=delete-char-forward
~によるとhttp://www.qnx.com/developers/docs/6.3.2/neutrino/utilities/k/ksh.html#bind、
prefix-2
Key binding: ^X, ^[[
Introduces a 2-character command sequence.
だから私の更新された質問はなぜこれを使うべきですかprefix-2
?私がもはやこの問題ですべての人を悩ませないように、私が理解できるように翻訳してください。
古いものが続きます
修正する
QNXのESCはです^[
。このコマンドを使用すると、カーソルがローカーソルの下のbind '^[[3~'='delete-char-backward'
文字を覆うことができます~
。少なくともある程度進展がありますね。今、スペルを書く方法を知っています。キーの削除殻のために。私がオンラインで見たほとんどのコンテンツには削除キーが呼ばれていますが、^?
私には該当しないようです。また、PuTTy経由でアクセスしていることにも言及する必要があります。
理解できません。コントロールD削除キーで目的の操作を実行します。私はそれを再バインドしようとしましたが、eot-or-delete
成功しませんでした。
これは簡単なはずですか?
アップデート2:
bind | grep prefix
^X = prefix-2
^[ = prefix-1
ÿ = prefix-3
^[O = prefix-2
^[[ = prefix-2
bind | grep '[^ -~]'
ÿ = prefix-3
à = beginning-of-line
à¡ = up-history
ठ= backward-char
ঠ= forward-char
ਠ= end-of-line
à© = down-history
ଠ= delete-char-forward
à´ = backward-word
ච= forward-word
アップデート3:私の設定に関する追加情報
環境設定
echo $ENV
/etc/kshrc
BIND完了出力
bind
^A = beginning-of-line
^B = backward-char
^C = abort
^D = eot-or-delete
^E = end-of-line
^F = forward-char
^G = abort
^H = delete-char-backward
^I = complete
^J = newline
^K = kill-to-eol
^L = redraw
^M = newline
^N = down-history
^O = newline-and-next
^P = up-history
^R = search-history
^T = transpose-chars
^U = kill-line
^V = version
^W = kill-region
^X = prefix-2
^Y = yank
^[ = prefix-1
^\ = no-op
^] = search-character-forward
^^ = quote
^_ = eot
^? = delete-char-backward
ÿ = prefix-3
^[^H = delete-word-backward
^[^X = complete-file
^[^[ = complete
^[^] = search-character-backward
^[ = set-mark-command
^[# = comment
^[* = expand-file
^[. = prev-hist-word
^[0 = set-arg
^[1 = set-arg
^[2 = set-arg
^[3 = set-arg
^[4 = set-arg
^[5 = set-arg
^[6 = set-arg
^[7 = set-arg
^[8 = set-arg
^[9 = set-arg
^[< = beginning-of-history
^[= = complete-list
^[> = end-of-history
^[? = list
^[C = capitalize-word
^[L = downcase-word
^[O = prefix-2
^[U = upcase-word
^[[ = prefix-2
^[_ = prev-hist-word
^[b = backward-word
^[c = capitalize-word
^[d = delete-word-forward
^[f = forward-word
^[g = goto-history
^[h = delete-word-backward
^[l = downcase-word
^[u = upcase-word
^[y = yank-pop
^[^? = delete-word-backward
^X^X = exchange-point-and-mark
^X^Y = list-file
^X^[ = complete-command
^X? = list-command
^XA = up-history
^XB = down-history
^XC = forward-char
^XD = backward-char
^XH = beginning-of-line
^XP = delete-char-forward
^XY = end-of-line
^Xc = forward-word
^Xd = backward-word
^Xw = end-of-line
à = beginning-of-line
à¡ = up-history
ठ= backward-char
ঠ= forward-char
ਠ= end-of-line
à© = down-history
ଠ= delete-char-forward
à´ = backward-word
ච= forward-word
/etc/kshrc
/etc # cat kshrc
case $- in
*i*)
export SHELL_COLOR_BLUE="print -n \\033[0;34m"
export SHELL_COLOR_GREEN="print -n \\033[0;32m"
export SHELL_COLOR_RED="print -n \\033[0;31m"
export SHELL_COLOR_LIGHTGRAY="print -n \\033[0;37m"
export SHELL_COLOR_YELLOW="print -n \\033[1;33m"
export COLOR_BLACK="\\033[0;30m"
export COLOR_BLUE="\\033[0;34m"
export COLOR_GREEN="\\033[0;32m"
export COLOR_CYAN="\\033[0;36m"
export COLOR_RED="\\033[0;31m"
export COLOR_PURPLE="\\033[0;35m"
export COLOR_BROWN="\\033[0;33m"
export COLOR_LIGHTGRAY="\\033[0;37m"
export COLOR_DARKGRAY="\\033[1;30m"
export COLOR_LIGHTBLUE="\\033[1;34m"
export COLOR_LIGHTGREEN="\\033[1;32m"
export COLOR_LIGHTCYAN="\\033[1;36m"
export COLOR_LIGHTRED="\\033[1;31m"
export COLOR_LIGHTPURPLE="\\033[1;35m"
export COLOR_YELLOW="\\033[1;33m"
export COLOR_WHITE="\\033[1;37m"
if [[ `id -u` -eq 0 ]]; then
export PS1=`$SHELL_COLOR_RED`'$(hostname -s):'`$SHELL_COLOR_YELLOW`'$(pwd) # '`$SHELL_COLOR_LIGHTGRAY`
else
export PS1=`$SHELL_COLOR_BLUE`'$(hostname -s):'`$SHELL_COLOR_GREEN`'$(pwd) $ '`$SHELL_COLOR_LIGHTGRAY`
fi
esac
パテ設定:
コメントは重要でも重要ではないかもしれませんが、文脈を提供できます。
シェルは「PD KSH v5.2.14 99/07/13.2」です。はい、アップグレードするオプションはありません。組み込みシステムです。 「現代のシェルを購入してください」は実行可能な答えではありません。オペレーティングシステムはQNX Neutrino 6.4.1です。
バインディングは以下を示しています。
bind | grep del
^D = eot-or-delete
^H = delete-char-backward
^? = delete-char-backward
^[^H = delete-word-backward
^[d = delete-word-forward
^[h = delete-word-backward
^[^? = delete-word-backward
^XP = delete-char-forward
ଠ= delete-char-forward
infocmp は以下を表示します。
infocmp # Reconstructed via infocmp from file:
/usr/lib/terminfo/x/xterm xterm|vs100|xterm terminal emulator,
am, km, mir, msgr, xenl, xon,
cols#80, it#8, lines#65, vt@,
acsc=Oa``aaffggjjkkllmmnnooppqqrrssttuuvvwwxxyyzz{{||}}~~,
bel=^G, blink=@, bold=\E[1m, clear=\E[H\E[2J, cr=^M,
csr=\E[%i%p1%d;%p2%dr, cub=\E[%p1%dD, cub1=^H,
cud=\E[%p1%dB, cud1=\E[B, cuf=\E[%p1%dC, cuf1=\E[C,
cup=\E[%i%p1%d;%p2%dH, cuu=\E[%p1%dA, cuu1=\E[A,
dch=\E[%p1%dP, dch1=\E[P, dl=\E[%p1%dM, dl1=\E[M, ed=\E[J,
el=\E[K, el1=\E[1K$<3>, enacs=\E(B\E)0, home=\E[H, ht=^I,
hts=\EH, ich=\E[%p1%d@, ich1=\E[2~, il=\E[%p1%dL, il1=\E[L,
ind=^J, is1=\E=\E[?1l, kBEG=\ENn, kCPY=\ENs, kCRT=\ENt,
kDL=\ENv, kEXT=\ENw, kFND=\ENx, kHLP=\ENy, kOPT=\ENz,
ka3=\EOs, kb2=\EOr, kbs=^H, kc1=\EOq, kcan=\EOm, kclo=\ENc,
kclr=\ENa, kcmd=\EOu, kcub1=\E[D, kcud1=\E[B, kcuf1=\E[C,
kcuu1=\E[A, kdch1=\E[P, kend=\E[9, kf1=\E[11~, kf10=\E[21~,
kf11=\E[23~, kf12=\E[24~, kf2=\E[12~, kf3=\E[13~,
kf4=\E[14~, kf5=\E[15~, kf6=\E[17~, kf7=\E[18~, kf8=\E[19~,
kf9=\E[20~, kfnd=\ENf, khlp=\ENh, khome=\E[8, khts=\ENb,
kich1=\E[2~, kmov=\ENi, kmrk=\ENm, kmsg=\ENe, knp=\E[6~,
kopn=\ENo, kopt=\ENk, kpp=\E[5~, kref=\ENl, kres=\ENp,
krfr=\ENg, krpl=\ENr, krst=\ENj, ksav=\ENq, kslt=\EOM,
ktbc=\ENd, kund=\ENu, rc=\E8, rev=\E[7m, ri=\EM, rmacs=^O,
rmam=\E[?7l, rmkx=\E>, rmso=\E[m,
rs1=\E>\E[1;3;4;5;6l\E[?7h\E[m\E[r\E[2J\E[H, rs2=@,
sc=\E7,
setb=\E[4%?%p1%{1}%=%t4%e%p1%{3}%=%t6%e%p1%{4}%=%t1%e%p1%{6}%=%t3%e%p1%d%;m,
setf=\E[3%?%p1%{1}%=%t4%e%p1%{3}%=%t6%e%p1%{4}%=%t1%e%p1%{6}%=%t3%e%p1%d%;m,
sgr=\E[0%?%p1%p6%|%t;1%;%?%p2%t;4%;%?%p1%p3%|%t;7%;%?%p4%t;5%;m,
sgr0=\E[m, smacs=^N, smam=\E[?7h, smkx=\E=, smso=\E[7m,
tbc=\E[3g,
stty は以下を表示します。
stty Name: /dev/ttyp0 Type: pseudo Opens: 2
+edit +echok +echonl
+osflow intr=^C quit=^\ erase=^? kill=^U eof=^D start=^Q stop=^S susp=^Z lnext=^V min=01 time=00 pr1=^[ pr2=5B left=44 right=43
up=41 down=42 ins=40 del=50 home=48 end=59
答え1
Googleの従業員の場合:
呼ぶ簡単にすることは難しいです。
これ短いソリューション次のコマンドを使用して、削除キー(.kshrc
または他の場所)を設定します。
bind '^[[3'=prefix-2
bind '^[[3~'=delete-char-forward
PuTTY端末設定rxvt
をStandard
。
これを行うのに実際に役立ったのは次のとおりです。http://www.mail-archive.com/[Eメール保護]/msg81796.html
ksh は home キーと end キーを使っていくつかの愚かな操作を行います。デフォルトでは、ホーム、終了、削除の違いを同時に区別することはできません。 3つのキーはすべて、最後のバインディングに関係なく機能します。 PuTTYがこれらのキーの送信内容を変更すると、多くの役に立ちます。
注:一部の人は、キーを押したときにシェルが取得するコードを表示するには、と入力してcat
Enterを押してからそのキーを押すように提案します。私のシェルではこれはうまくいきません。~
コントロールキーをすべて取得しました。私がすることはEsc
一度押してからキーを押すことです。これにより制御コードが表示されます。この制御コードを使用してbind
ください。
答え2
シェルがGNOME端末ウィンドウ内で実行されている場合をクリックするとメニューが次に移動します。Edit
|プロファイルを選択し、タブを選択してに変更します。 (または失敗した場合は、他のオプションを試してください。)Preferences
Profiles
Compatibility
Delete key generates
Automatic
^v Del
または^v Backspace
、(Control-vの後にDelete、Control-vの後にバックスペース)を入力して、返されたターミナルシーケンスコードを見つけることもできます。
確認するには、以下を使用してください。showkey
コマンドはshowkey -s
およびshowkey -k
/またはshowkey -a
(つまり3つのレイヤー)で、キーを押します。Del
Backspace
I) キーボードの生出力
II) tty ドライバの出力
III) (ansi) 端末に提供される文字列
これから、stty(stty1など)を使用すると、シェルがxterm(グラフィックX端末内)を使用するときとは異なる動作をすることがわかりました。 Delはstty1から前方(右側)を正しく削除しますが、xtermでは後方(左側)を正しく削除します。
答え3
gnome ターミナルを使用して Linux (Ubuntu 18.10) bash から SSH 経由で Solaris 11.3 bash まで、従来の 2 つの回答は機能しませんでした.
そのコマンドを使用する必要があることがわかりましたbind
が、基本機能を取得できないため、回避策がありますDelete。
だから解決策はDelete押す時です。シミュレーション削除キーをおよびにマッピングして→削除しますBackspace。
bind '"^[[3~":"^[[C^?"'
これを入力するには、次のキーを使用します。
CTRL-vDelete1部
とCTRL-v→CTRL-vBackspace2部の場合。
(または\e
例えば脱出のために"\e[3~"
:)
完璧ではありません。Delete行の末尾にある場合は、まだバックスペースに移動します。ただし、~
この文字を1日にも数え切れなくバックスペースに移動する必要はありません。
答え4
man ksh
私のDebian 10システムによると、prefix-1
「2文字のコマンドシーケンスが導入されました」そしてprefix-2
「マルチキャラコマンドシーケンスが導入されました。」本質的に、彼らはシェルに「まだ処理しないでください。長い文字シーケンスが必要です。シーケンス全体を待ってください」と言います。
最新のUnix / Linuxターミナルセッションは通常、以下で実行されます。端末エミュレータ:本質的に特定のタイプをシミュレートします(拡張バージョン)。コンピュータ端末シリアルポートを介して接続します。多くの端末では、キーボードキーとコンピュータに送信される文字の間のマッピングは厳密に一対一で行われません。キーボードのすべてのさまざまな非文字キーに標準化されたASCII制御文字がないため、一部のキーは複数のキーを送信します。性格。文字の順序。ファンクションキー、矢印キー、、、、、Homeおよびこのグループに属します。EndInsertDeletePgUpPgDn
キーは、つまり+Escと表示されます。 ASCIIコード表を見ると、キーがデフォルトで組み合わされたプレーン文字の値から64を引くこと(つまり、1ビット反転)がわかります。特殊名「ESC」を持つASCII制御文字も同様です。^[
Control[Control^[
出力には、 と認識されるとマークされbind | grep prefix
ます。^[
prefix-1
^[[
prefix-2
キーDeleteは実際に同等のシーケンスを送信しますEsc [ 3 ~。
したがって、シェルは次のように一度に1文字/バイトずつ解析する必要があります。
- 受信済みEsc:
^[
「一致」とも呼ばれるprefix-1
ため、少なくとも1文字が表示されるのを待ってから、次のように組み合わせてください。 - 受信済み[:前のプレフィックス文字と組み合わせて
^[[
一致するprefix-2
ので、さらに待ってから文字結合を続けます。 - receive 3: 前のプレフィックスと組み合わせると
^[[3
再びなりますので、prefix-2
待ち続けて結合してください。 - 受信~:現在の組み合わせが
^[[3~
のバインディングと一致しますdelete-char-forward
。