답변:
것처럼 M-.
(메타 도트 또는 ESC 도트 Alt 키 도트)를 readline에 함수이며 yank-last-arg
, M-C-y
(메타 제어 Y 또는 ESC-CTRL-Y 또는 Ctrl + Alt + Y)을 readline에 함수이다 yank-nth-arg
. 을 지정하지 않으면 n
이전 명령의 첫 번째 인수를 취소합니다.
인수를 지정하려면 Esc 키와 숫자를 누르거나 Alt 키를 누른 상태에서 숫자를 누르십시오. 당신은 할 수 있습니다 Alt- -음수를 지정한 다음 Alt를 놓고 숫자를 누르십시오 (이것은 인수 목록의 끝에서 계산됩니다.
예:
다음 명령을 입력하십시오
$ echo a b c d e f g
a b c d e f g
이제 다음 프롬프트에서 echo
(다음 공백으로)를 입력 한 다음
보도 Alt- Ctrl- y당신은 지금 볼 수 있습니다 :
$ echo a
Enter아직 누르지 않고 다음을 수행하십시오.
보도 Alt- 3 Alt- Ctrl-y
보도 Alt- - 2 Alt- Ctrl-y
이제 당신은 볼 것이다 :
$ echo ace
그건 그렇고, echo
인수 0을 선택하여 줄에 넣을 수 있습니다 .
보도 Alt- 0 Alt- Ctrl-y
편집하다:
원본에 추가 한 질문에 대답하려면 :
당신은 누를 수 있습니다 Alt- 0다음 반복적으로 눌러 Alt- .단계를 이전 명령을 통해 (ARG 0)입니다. 마찬가지로 Alt- -다음 반복 Alt- .이전 다음 - 투 - 마지막으로 인수를 단계별로 허용합니다.
히스토리의 특정 라인에 적절한 인수가 없으면 벨이 울립니다.
자주 사용하는 특정 조합이 있으면 한 번의 키 입력으로 매크로를 정의 할 수 있습니다. 이 예는 눌러 이전 명령의 두 번째 인수를 기억한다 Alt- Shift- Y. 이 키 대신 원하는 키를 선택할 수 있습니다. 반복해서 누르면 이전 단계를 진행할 수 있습니다.
그것을 시도하려면 Bash 프롬프트에서 매크로를 입력하십시오.
bind '"\eY": "\e2\e."'
지속성을 유지하려면 ~/.inputrc
파일에 다음 줄을 추가 하십시오.
"\eY": "\e2\e."
불행히도 이것은 arg 0 또는 음수 인수 번호에는 작동하지 않는 것 같습니다.
-s
(Bash 4의 새로운 기능)은을 사용하여 생성 된 매크로를 나열합니다 -x
.
M-.
:뿐만 아니라 Alt-3
Alt-Ctrl-y
예를 들고 같음을 위해 Alt
하고 입력 3.
. 3.
해제하지 않고 여러 번 입력 Alt
하면 이전 명령 줄의 세 번째 인수를 거치게됩니다.
!$
이전 명령 줄 인수의 마지막 요소를 가져옵니다.
!:3
당신에게 세 번째를 얻을 수
!!
마지막 명령 전체를 얻습니다. 사용을 잊어 버린 경우에 유용합니다 sudo
.
!:1-2
마지막 3 가지 논거를 제외하고 모두를 얻는다
echo foo{,bar} baz
하면 명령이 인쇄 된 것으로 기록되고 나중에 확장됩니다. 위와 같이 echo !:1
after를 사용 하면 echo foo{,bar}
다음으로 확장되어 확장됩니다.echo foo foobar
첫 번째 인수를 사용하려면 !^
또는!:1
예:
$ echo a b c d e
a b c d e
$ echo !^
echo a
a
$ echo a b c d e
a b c d e
$ echo !:1
echo a
a
귀하의 질문은 다른 인수를 사용하는 것에 관한 것이므로 다음과 같은 유용한 인수가 있습니다.
!^ first argument
!$ last argument
!* all arguments
!:2 second argument
!:2-3 second to third arguments
!:2-$ second to last arguments
!:2* second to last arguments
!:2- second to next to last arguments
!:0 the command
!! repeat the previous line
처음 네 가지 형태가 더 자주 사용됩니다. 이 형식 !:2-
은 마지막 인수를 포함하지 않으므로 다소 직관적이지 않습니다.
file3
에서 mv file1 file2 file3 target/
?
@larsmans의 답변이 너무 좋아서 더 많은 것을 배워야했습니다. 이 답변을 추가하면 다른 사람들이 매뉴얼 페이지 섹션을 찾고 Google에서 무엇을해야하는지 알 수 있습니다.
$ man -P 'less -p ^HISTORY\ EXPANSION' bash
<...>
Word Designators
Word designators are used to select desired words from the event.
A : separates the event specification from the word designator.
It may be omitted if the word designator begins with a ^, $, *, -,
or %. Words are numbered from the beginning of the line, with the
first word being denoted by 0 (zero). Words are inserted into the
current line separated by single spaces.
0 (zero)
The zeroth word. For the shell, this is the command word.
n The nth word.
^ The first argument. That is, word 1.
$ The last argument.
% The word matched by the most recent ‘?string?’ search.
x-y A range of words; ‘-y’ abbreviates ‘0-y’.
* All of the words but the zeroth.
This is a synonym for ‘1-$’.
It is not an error to use * if there is just one word in
the event; the empty string is returned in that case.
x* Abbreviates x-$.
x- Abbreviates x-$ like x*, but omits the last word.
If a word designator is supplied without an event
specification, the previous command is used as the event.
! ^는 첫 번째 인수에 대한 명령 일 수 있습니다. n 번째를 얻는 방법이 있는지 확실하지 않습니다.
!:n
있습니까?하지만 시작이 아닌 끝에서 계산합니까?
당신은 또한 당신의 역사에있는 어떤 명령으로부터도 논쟁을 얻을 수 있습니다!
$ echo a b c d e f g
a b c d e f g
$ echo build/libs/jenkins-utils-all-0.1.jar
build/libs/jenkins-utils-all-0.1.jar
$ history | tail -5
601 echo build/libs/jenkins-utils-all-0.1.jar
602 history | tail -10
603 echo a b c d e f g
604 echo build/libs/jenkins-utils-all-0.1.jar
605 history | tail -5
$ echo !-3:4
echo d
d
$ echo !604:1
echo build/libs/jenkins-utils-all-0.1.jar
build/libs/jenkins-utils-all-0.1.jar
Linux에서는 명령을 반복하여 기록으로 돌아갈 수 있습니다
마지막 명령은 :
mv foo bar
mv
foo
mv foo
이것을 실행하거나 ~/.zshrc
autoload -Uz copy-earlier-word
zle -N copy-earlier-word
bindkey "^[:" copy-earlier-word
이제 Alt+ .를 사용 하여 원하는대로 되돌아 간 다음 Alt+ :를 사용하여 인수를 반복하십시오.
마지막 명령을 가정하면
echo 1 2 3 4 5
5
4
3
2
1
echo
출처 : https://stackoverflow.com/a/34861762/3163120
bind -lp
bindkey -L
나는이 요점에서 이것을 최신 상태로 유지하고있다 https://gist.github.com/madacol/da38e42d7e45c2949a9f425cc20543e9
Alt .
Mac의 Zsh에서 ≥
🤔을 입력 중입니다.
bindkey -L
하여 모든 바로 가기가 바인드되어 있는지 확인할 수 있습니다 . 어쩌면 문제를 찾아내는 데 도움이되거나 다른 유용한 명령을 찾을 수도 있습니다. 필자의 경우 예를 들어 바인딩 은로 정의됩니다 . (화면을 지우려면)-> . -> ( 마지막 단어를 제거하는 것과 동일 )Alt .
bindkey "^[." insert-last-word
Ctrl L
bindkey "^L" clear-screen
Alt+Ctrl h
bindkey "^[^H" backward-kill-word
Ctrl w
bindkey "^[^_" copy-prev-word
기본적으로 이전 (명령) 인수 를 yanking하는 데 사용됩니다 .
예를 들어, 다음 명령이 발행 된 경우 :
echo Hello, world how are you today?
그리고, Hello,
제 인수되고 여섯째 마지막 하나이고; 다음을 입력하여 참조 할 수 있음을 의미합니다.today?
Alt+6 뒤에 Ctrl-Alt-6
Ctrl전통적으로 모자 문자로 표시되는 ^
키 이름 앞에 추가하고, Alt같은 M-
즉 M의 ETA의 접두사.
따라서 위의 지름길 ^My
을 잡아 당기도록 재정의 할 수 있습니다 .
또한 명령 행에 모자 대체 단축키가 있습니다.
echo Hello, world!
^Hello^Bye
Bye, world!
이전 명령의 첫 번째 일치 문자열 을 대체하려면 다음을 의미합니다.
Hello, world! Hello, people!
^Hello^Bye
결과 :
Bye, world! Hello, people!
두 번째 일치 ( hello
)는 그대로 유지합니다.
참고 : hats 사이에 공간을 두지 마십시오 . 그렇지 않으면 작업이 작동하지 않습니다.
위의 바로 가기는 다음과 같습니다.
!:s/Hello/Bye
이전 명령의 제 실측치 (일치) 문자열을 일정 수준 (*) 교체는 함께 첫 번째 부분 접두어 동안 g
스위치에 적용되는 전체 광고 g lobally :
echo Hello, world! Hello, people!
!:gs/Hello/Bye
Bye, world! Bye, people!
같은 보통 기타 관련 명령에서 수행되고 sed
, vi
그리고의 regex
(정규 표현식) - (검색 할 수있는의 standart 방법 일치하는 문자열 ).
아니, 당신은 할 수 없습니다
!:sg/Hello/Bye
또는!:s/Hello/Bye/g
여기, 구문입니다 !
그것은 내가 직접 사용하고 매뉴얼 페이지, 블로그 및 포럼을 포함한 다양한 출처에서 읽은 내용을 직접 시도하여 이해 한 것입니다.
서버 ( 서버 OS )를 포함한 많은 배포판에서 기본 쉘이 무엇인지 bash
, Bourne-Again 쉘 (발명 체 sh
자체, 발명가 성 뒤에 Bourne 쉘이라고 함)의 신비한 방법에 약간의 빛을 비추기 를 바랍니다 .
! ^는 첫 번째 매개 변수를 가져오고! $는 마지막 매개 변수 를 가져옵니다 ! : n 은 n 번째 요소를 가져옵니다.
bind -lp
찾을 때 현재 바인딩을 실행 하고 보는 것이 좋습니다.