Observação
O acesso a essa página exige autorização. Você pode tentar entrar ou alterar diretórios.
O acesso a essa página exige autorização. Você pode tentar alterar os diretórios.
Descrição curta
O PSReadLine fornece uma experiência aprimorada de edição de linha de comando no console do PowerShell.
Descrição longa
O PSReadLine 2.0 fornece uma experiência avançada de edição de linha de comando para o console do PowerShell. Ele fornece:
- Coloração de sintaxe da linha de comando
- Uma indicação visual de erros de sintaxe
- Uma melhor experiência de várias linhas (edição e histórico)
- Associações de chave personalizáveis
- Modos cmd e emacs
- Muitas opções de configuração
- Conclusão do estilo Bash (opcional no modo Cmd, padrão no modo Emacs)
- Emacs puxar/matar anel
- Movimentação e exclusão baseadas em token do PowerShell
O PSReadLine requer o PowerShell 3.0 ou mais recente. O PSReadLine funciona com host de console padrão, Visual Studio Code e Terminal de Janela. Ele não funciona no ISE do PowerShell.
O PSReadLine 2.1.0 é fornecido com o PowerShell 7.2 e tem suporte em todas as versões com suporte do PowerShell. Ele está disponível para instalação na Galeria do PowerShell. Para instalar o PSReadLine 2.1.0 em uma versão com suporte do PowerShell, execute o comando a seguir.
Install-Module -Name PSReadLine -RequiredVersion 2.1.0
Nota
A partir do PowerShell 7.0, o PowerShell ignorará o carregamento automático do PSReadLine no Windows se um programa de leitor de tela for detectado. Atualmente, o PSReadLine não funciona bem com os leitores de tela. A renderização e a formatação padrão do PowerShell 7.0 no Windows funcionam corretamente. Você pode carregar manualmente o módulo, se necessário.
As funções a seguir estão disponíveis na classe Microsoft.PowerShell.PSConsoleReadLine.
Funções básicas de edição
Abortar
Anulação da ação atual, por exemplo: pesquisa de histórico incremental.
- Emacs:
<Ctrl+g>
Aceitare e obtenhaPróximo
Tente executar a entrada atual. Se ele puder ser executado (como AcceptLine), lembre-se do próximo item do histórico na próxima vez em que ReadLine for chamado.
- Emacs:
<Ctrl+o>
Linha de Aceitação
Tente executar a entrada atual. Se a entrada atual estiver incompleta (por exemplo, há um parêntese de fechamento ausente, colchete ou aspas), o prompt de continuação será exibido na próxima linha e PSReadLine aguardará as chaves editarem a entrada atual.
- Cmd:
<Enter> - Emacs:
<Enter> - Modo de inserção vi:
<Enter>
AddLine
O prompt de continuação é exibido na próxima linha e o PSReadLine aguarda chaves para editar a entrada atual. Isso é útil para inserir a entrada de várias linhas como um único comando, mesmo quando uma única linha é a entrada completa por si só.
- Cmd:
<Shift+Enter> - Emacs:
<Shift+Enter> - Modo de inserção vi:
<Shift+Enter> - Modo de comando vi:
<Shift+Enter>
BackwardDeleteChar
Exclua o caractere antes do cursor.
- Cmd:
<Backspace>,<Ctrl+h> - Emacs:
<Backspace>,<Ctrl+Backspace>,<Ctrl+h> - Modo de inserção vi:
<Backspace> - Modo de comando Vi:
<X>,<d,h>
BackwardDeleteLine
Como BackwardKillLine – exclui o texto do ponto até o início da linha, mas não coloca o texto excluído no anel de exclusão.
- Cmd:
<Ctrl+Home> - Modo de inserção vi:
<Ctrl+u>,<Ctrl+Home> - Modo de comando Vi:
<Ctrl+u>,<Ctrl+Home>,<d,0>
BackwardDeleteWord
Exclui a palavra anterior.
- Modo de comando Vi:
<Ctrl+w>,<d,b>
Linha de Morte para Trás
Desmarque a entrada do início da entrada para o cursor. O texto desmarcado é colocado no anel de eliminação.
- Emacs:
<Ctrl+u>,<Ctrl+x,Backspace>
Palavras para trás
Desmarque a entrada do início da palavra atual para o cursor. Se o cursor estiver entre palavras, a entrada será desmarcada do início da palavra anterior para o cursor. O texto desmarcado é colocado no anel de eliminação.
- Cmd:
<Ctrl+Backspace>,<Ctrl+w> - Emacs:
<Alt+Backspace>,<Escape,Backspace> - Modo de inserção vi:
<Ctrl+Backspace> - Modo de comando vi:
<Ctrl+Backspace>
Cancelar Linha
Cancele a entrada atual, deixando a entrada na tela, mas retorne ao host para que o prompt seja avaliado novamente.
- Modo de inserção vi:
<Ctrl+c> - Modo de comando vi:
<Ctrl+c>
Copiar
Copie a região selecionada para a área de transferência do sistema. Se nenhuma região estiver selecionada, copie a linha inteira.
- Cmd:
<Ctrl+C>
CopyOrCancelLine
Se o texto estiver selecionado, copie para a área de transferência, caso contrário, cancele a linha.
- Cmd:
<Ctrl+c> - Emacs:
<Ctrl+c>
Cortar
Exclua a região selecionada colocando o texto excluído na área de transferência do sistema.
- Cmd:
<Ctrl+x>
ExcluirChar
Exclua o caractere sob o cursor.
- Cmd:
<Delete> - Emacs:
<Delete> - Modo de inserção vi:
<Delete> - Modo de comando Vi:
<Delete>,<x>,<d,l>,<d,Spacebar>
ExcluirCharOrExit
Exclua o caractere sob o cursor ou, se a linha estiver vazia, saia do processo.
- Emacs:
<Ctrl+d>
DeleteEndOfBuffer
Exclui até o final do buffer de várias linhas.
- Modo de comando vi:
<d,G>
ExcluirEndOfWord
Excluir até o final da palavra.
- Modo de comando vi:
<d,e>
Linha de exclusão
Exclui a linha lógica atual de um buffer multilinha, permitindo desfazer.
- Modo de comando Vi:
<d,d>,<d,_>
ExcluirLinhas Anteriores
Exclui as linhas lógicas solicitadas anteriormente e a linha lógica atual em um buffer de várias linhas.
- Modo de comando vi:
<d,k>
ExcluirLinhas Relativas
Exclui do início do buffer para a linha lógica atual em um buffer de várias linhas.
Como a maioria dos comandos Vi, o comando <d,g,g> pode ser acrescentado com um argumento numérico que especifica um número de linha absoluto, que, juntamente com o número de linha atual, compõem um intervalo de linhas a serem excluídas.
Se não for especificado, o argumento numérico padrão será 1, que se refere à primeira linha lógica em um buffer multilinha.
O número real de linhas a serem excluídas da multilinha é computado como a diferença entre o número de linha lógica atual e o argumento numérico especificado, que pode, portanto, ser negativo. Portanto, o relativo parte do nome do método.
- Modo de comando vi:
<d,g,g>
ExcluirPróximaLinhas
Exclui a linha lógica atual e as próximas linhas lógicas solicitadas em um buffer de várias linhas.
- Modo de comando vi:
<d,j>
ExcluirLinhaParaPrimeiroCaractere
Exclui o texto do cursor para o primeiro caractere não em branco da linha.
- Modo de comando vi:
<d,^>
ExcluirParaFim
Excluir até o final da linha.
- Modo de comando Vi:
<D>,<d,$>
Excluir palavra
Exclua a próxima palavra.
- Modo de comando vi:
<d,w>
ForwardDeleteLine
Assim como ForwardKillLine - exclui o texto do ponto até o final da linha, mas não coloca o texto excluído no anel de exclusão.
- Cmd:
<Ctrl+End> - Modo de inserção vi:
<Ctrl+End> - Modo de comando vi:
<Ctrl+End>
Inserir Linha Acima
Uma nova linha vazia é criada acima da linha atual, independentemente de onde o cursor esteja na linha atual. O cursor passa para o início da nova linha.
- Cmd:
<Ctrl+Enter>
InsertLineBelow
Uma nova linha vazia é criada abaixo da linha atual, independentemente de onde o cursor esteja na linha atual. O cursor passa para o início da nova linha.
- Cmd:
<Shift+Ctrl+Enter>
InvertCase
Inverta o caso do caractere atual e vá para o próximo.
- Modo de comando vi:
<~>
Linha de Matar
Desmarque a entrada do cursor até o final da entrada. O texto desmarcado é colocado no anel de eliminação.
- Emacs:
<Ctrl+k>
Região de Matar
Mate o texto entre o cursor e a marca.
- A função não está relacionada.
Palavra de Morte
Desmarque a entrada do cursor até o final da palavra atual. Se o cursor estiver entre palavras, a entrada será desmarcada do cursor até o final da próxima palavra. O texto desmarcado é colocado no anel de eliminação.
- Cmd:
<Alt+d>,<Ctrl+Delete> - Emacs:
<Alt+d>,<Escape,d> - Modo de inserção vi:
<Ctrl+Delete> - Modo de comando vi:
<Ctrl+Delete>
Colar
Cole o texto da área de transferência do sistema.
- Cmd:
<Ctrl+v>,<Shift+Insert> - Modo de inserção vi:
<Ctrl+v> - Modo de comando vi:
<Ctrl+v>
Importante
Ao usar a função Colar, todo o conteúdo do buffer da área de transferência é colado no buffer de entrada do PSReadLine. Em seguida, o buffer de entrada é passado para o analisador do PowerShell. A entrada colada usando o aplicativo de console clique com o botão direito do mouse método de colagem é copiada para o buffer de entrada um caractere de cada vez. O buffer de entrada é passado para o analisador quando um caractere de nova linha é copiado. Portanto, a entrada é analisada uma linha de cada vez. A diferença entre métodos de colagem resulta em um comportamento de execução diferente.
Cole depois
Cole a área de transferência após o cursor, movendo o cursor para o final do texto colado.
- Modo de comando vi:
<p>
ColarAntes
Cole a área de transferência antes do cursor, movendo o cursor para o final do texto colado.
- Modo de comando vi:
<P>
PrependAndAccept
Prepare um '#' e aceite a linha.
- Modo de comando vi:
<#>
Refazer
Desfazer uma desfazer.
- Cmd:
<Ctrl+y> - Modo de inserção vi:
<Ctrl+y> - Modo de comando vi:
<Ctrl+y>
RepeatLastCommand
Repita a última modificação de texto.
- Modo de comando vi:
<.>
RevertLine
Reverte toda a entrada para a entrada atual.
- Cmd:
<Escape> - Emacs:
<Alt+r>,<Escape,r>
ShellBackwardKillWord
Desmarque a entrada do início da palavra atual para o cursor. Se o cursor estiver entre palavras, a entrada será desmarcada do início da palavra anterior para o cursor. O texto desmarcado é colocado no anel de eliminação.
A função não está relacionada.
ShellKillWord
Desmarque a entrada do cursor até o final da palavra atual. Se o cursor estiver entre palavras, a entrada será desmarcada do cursor até o final da próxima palavra. O texto desmarcado é colocado no anel de eliminação.
A função não está relacionada.
Caracteres de troca
Troque o caractere atual e o anterior.
- Emacs:
<Ctrl+t> - Modo de inserção vi:
<Ctrl+t> - Modo de comando vi:
<Ctrl+t>
Desfazer
Desfazer uma edição anterior.
- Cmd:
<Ctrl+z> - Emacs:
<Ctrl+_>,<Ctrl+x,Ctrl+u> - Modo de inserção vi:
<Ctrl+z> - Modo de comando Vi:
<Ctrl+z>,<u>
Desfazer tudo
Desfazer todas as edições anteriores para linha.
- Modo de comando vi:
<U>
UnixWordRubout
Desmarque a entrada do início da palavra atual para o cursor. Se o cursor estiver entre palavras, a entrada será desmarcada do início da palavra anterior para o cursor. O texto desmarcado é colocado no anel de eliminação.
- Emacs:
<Ctrl+w>
ValidateAndAcceptLine
Tente executar a entrada atual. Se a entrada atual estiver incompleta (por exemplo, há um parêntese de fechamento ausente, colchete ou aspas), o prompt de continuação será exibido na próxima linha e PSReadLine aguardará as chaves editarem a entrada atual.
- Emacs:
<Ctrl+m>
ViAcceptLine
Aceite a linha e alterne para o modo Inserir.
- Modo de comando vi:
<Enter>
ViAcceptLineOrExit
Como DeleteCharOrExit no modo Emacs, mas aceita a linha em vez de excluir um caractere.
- Modo de inserção vi:
<Ctrl+d> - Modo de comando vi:
<Ctrl+d>
ViAppendLine
Uma nova linha é inserida abaixo da linha atual.
- Modo de comando vi:
<o>
ViBackwardDeleteGlob
Exclui a palavra anterior, usando apenas o espaço em branco como delimitador de palavras.
- Modo de comando vi:
<d,B>
ViBackwardGlob
Move o cursor de volta para o início da palavra anterior, usando apenas o espaço em branco como delimitadores.
- Modo de comando vi:
<B>
ViDeleteBrace
Localize a chave correspondente, parênteses ou colchete e exclua todo o conteúdo dentro, incluindo a chave.
- Modo de comando vi:
<d,%>
ViDeleteEndOfGlob
Excluir até o final da palavra.
- Modo de comando vi:
<d,E>
ViDeleteGlob
Exclua o próximo glob (palavra delimitada por espaço em branco).
- Modo de comando vi:
<d,W>
ViDeleteToBeforeChar
Exclui até determinado caractere.
- Modo de comando vi:
<d,t>
ViDeleteToBeforeCharBackward
Exclui até determinado caractere.
- Modo de comando vi:
<d,T>
ViDeleteToChar
Exclui até determinado caractere.
- Modo de comando vi:
<d,f>
ViDeleteToCharBackward
Exclui para trás até determinado caractere.
- Modo de comando vi:
<d,F>
ViInsertAtBegining
Alterne para o modo Inserir e posicione o cursor no início da linha.
- Modo de comando vi:
<I>
ViInsertAtEnd
Alterne para o modo Inserir e posicione o cursor no final da linha.
- Modo de comando vi:
<A>
ViInsertLine
Uma nova linha é inserida acima da linha atual.
- Modo de comando vi:
<O>
ViInsertWithAppend
Acrescente da posição da linha atual.
- Modo de comando vi:
<a>
ViInsertWithDelete
Exclua o caractere atual e alterne para o modo Inserir.
- Modo de comando vi:
<s>
ViJoinLines
Une a linha atual e a próxima linha.
- Modo de comando vi:
<J>
ViReplaceLine
Apago toda a linha de comando.
- Modo de comando Vi:
<S>,<c,c>
ViReplaceToBeforeChar
Substitui até determinado caractere.
- Modo de comando vi:
<c,t>
ViReplaceToBeforeCharBackward
Substitui até determinado caractere.
- Modo de comando vi:
<c,T>
ViReplaceToChar
Exclui até determinado caractere.
- Modo de comando vi:
<c,f>
ViReplaceToCharBackward
Substitui até determinado caractere.
- Modo de comando vi:
<c,F>
ViYankBeginningOfLine
Puxe do início do buffer para o cursor.
- Modo de comando vi:
<y,0>
ViYankEndOfGlob
Puxe do cursor até o final do WORD(s).
- Modo de comando vi:
<y,E>
ViYankEndOfWord
Puxe do cursor até o final da(s) palavra(s).
- Modo de comando vi:
<y,e>
ViYankLeft
Puxe caracteres à esquerda do cursor.
- Modo de comando vi:
<y,h>
ViYankLine
Puxe todo o buffer.
- Modo de comando vi:
<y,y>
ViYankNextGlob
Puxe do cursor para o início do próximo WORD(s).
- Modo de comando vi:
<y,W>
ViYankNextWord
Puxe a palavra após o cursor.
- Modo de comando vi:
<y,w>
ViYankPercent
Puxe de/para a chave correspondente.
- Modo de comando vi:
<y,%>
ViYankAnteriorGlob
Puxe do início do WORD(s) para o cursor.
- Modo de comando vi:
<y,B>
ViYankAnteriorPalavra
Puxe a(s) palavra(s) antes do cursor.
- Modo de comando vi:
<y,b>
ViYankRight
Puxe caracteres para baixo e à direita do cursor.
- Modo de comando Vi:
<y,l>,<y,Spacebar>
ViYankToEndOfLine
Puxe do cursor até o final do buffer.
- Modo de comando vi:
<y,$>
ViYankToFirstChar
Puxe do primeiro caractere não whitespace para o cursor.
- Modo de comando vi:
<y,^>
Ianque
Adicione o texto morto mais recentemente à entrada.
- Emacs:
<Ctrl+y>
YankLastArg
Puxe o último argumento da linha de histórico anterior. Com um argumento, a primeira vez que ele é invocado, comporta-se exatamente como YankNthArg. Se invocado várias vezes, em vez disso, itera por meio do histórico e o arg define a direção (negativo inverte a direção).)
- Cmd:
<Alt+.> - Emacs:
<Alt+.>,<Alt+_>,<Escape,.>,<Escape,_>
YankNthArg
Puxe o primeiro argumento (após o comando) da linha de histórico anterior. Com um argumento, remova o nth argumento (a partir de 0), se o argumento for negativo, comece do último argumento.
- Emacs:
<Ctrl+Alt+y>,<Escape,Ctrl+y>
YankPop
Se a operação anterior fosse Yank ou YankPop, substitua o texto anteriormente arrancado pelo texto morto seguinte do anel de eliminação.
- Emacs:
<Alt+y>,<Escape,y>
Funções de movimento do cursor
BackwardChar
Mova o cursor um caractere para a esquerda. Isso pode mover o cursor para a linha anterior de entrada de várias linhas.
- Cmd:
<LeftArrow> - Emacs:
<LeftArrow>,<Ctrl+b> - Modo de inserção vi:
<LeftArrow> - Modo de comando Vi:
<LeftArrow>,<Backspace>,<h>
Palavra anterior
Mova o cursor de volta para o início da palavra atual ou, se entre palavras, o início da palavra anterior. Os limites do Word são definidos por um conjunto configurável de caracteres.
- Cmd:
<Ctrl+LeftArrow> - Emacs:
<Alt+b>,<Escape,b> - Modo de inserção vi:
<Ctrl+LeftArrow> - Modo de comando vi:
<Ctrl+LeftArrow>
Os caracteres que definem limites de palavra são configurados na propriedade WordDelimiters do objeto PSConsoleReadLineOptions. Para exibir ou alterar a propriedade WordDelimiters, consulte Get-PSReadLineOption e Set-PSReadLineOption.
Começo de Linha
Se a entrada tiver várias linhas, vá para o início da linha atual ou, se já estiver no início da linha, vá para o início da entrada. Se a entrada tiver uma única linha, vá para o início da entrada.
- Cmd:
<Home> - Emacs:
<Home>,<Ctrl+a> - Modo de inserção vi:
<Home> - Modo de comando vi:
<Home>
Fim da Linha
Se a entrada tiver várias linhas, vá para o final da linha atual ou, se já estiver no final da linha, vá para o final da entrada. Se a entrada tiver uma única linha, vá para o final da entrada.
- Cmd:
<End> - Emacs:
<End>,<Ctrl+e> - Modo de inserção vi:
<End>
ForwardChar
Mova o cursor um caractere para a direita. Isso pode mover o cursor para a próxima linha de entrada de várias linhas.
- Cmd:
<RightArrow> - Emacs:
<RightArrow>,<Ctrl+f> - Modo de inserção vi:
<RightArrow> - Modo de comando Vi:
<RightArrow>,<Space>,<l>
Palavra de encaminhamento
Mova o cursor para a frente até o final da palavra atual, ou se entre palavras, para o final da próxima palavra. Os limites do Word são definidos por um conjunto configurável de caracteres.
- Emacs:
<Alt+f>,<Escape,f>
Os caracteres que definem limites de palavra são configurados na propriedade WordDelimiters do objeto PSConsoleReadLineOptions. Para exibir ou alterar a propriedade WordDelimiters, consulte Get-PSReadLineOption e Set-PSReadLineOption.
Ir para Brace
Vá para a chave correspondente, parêntese ou colchete.
- Cmd:
<Ctrl+]> - Modo de inserção vi:
<Ctrl+]> - Modo de comando vi:
<Ctrl+]>
Ir para Coluna
Mova para a coluna indicada por arg.
- Modo de comando vi:
<|>
GotoFirstNonBlankOfLine
Mova o cursor para o primeiro caractere não em branco na linha.
- Modo de comando Vi:
<^>,<_>
MoverParaEndOfLine
Mova o cursor para o final da entrada.
- Modo de comando Vi:
<End>,<$>
Linha Seguinte
Mova o cursor para a próxima linha.
- A função não está relacionada.
PróximoPalavra
Mova o cursor para a frente até o início da próxima palavra. Os limites do Word são definidos por um conjunto configurável de caracteres.
- Cmd:
<Ctrl+RightArrow> - Modo de inserção vi:
<Ctrl+RightArrow> - Modo de comando vi:
<Ctrl+RightArrow>
Os caracteres que definem limites de palavra são configurados na propriedade WordDelimiters do objeto PSConsoleReadLineOptions. Para exibir ou alterar a propriedade WordDelimiters, consulte Get-PSReadLineOption e Set-PSReadLineOption.
PróximoPalavraFim
Mova o cursor para a frente até o final da palavra atual, ou se entre palavras, para o final da próxima palavra. Os limites do Word são definidos por um conjunto configurável de caracteres.
- Modo de comando vi:
<e>
Os caracteres que definem limites de palavra são configurados na propriedade WordDelimiters do objeto PSConsoleReadLineOptions. Para exibir ou alterar a propriedade WordDelimiters, consulte Get-PSReadLineOption e Set-PSReadLineOption.
Linha Anterior
Mova o cursor para a linha anterior.
- A função não está relacionada.
ShellBackwardWord
Mova o cursor de volta para o início da palavra atual ou, se entre palavras, o início da palavra anterior. Os limites do Word são definidos por tokens do PowerShell.
- A função não está relacionada.
ShellForwardWord
Mova o cursor para a frente até o início da próxima palavra. Os limites do Word são definidos por tokens do PowerShell.
- A função não está relacionada.
ShellNextWord
Mova o cursor para a frente até o final da palavra atual, ou se entre palavras, para o final da próxima palavra. Os limites do Word são definidos por tokens do PowerShell.
- A função não está relacionada.
ViBackwardChar
Mova o cursor um caractere para a esquerda no modo de edição do Vi. Isso pode mover o cursor para a linha anterior de entrada de várias linhas.
- Modo de inserção vi:
<LeftArrow> - Modo de comando Vi:
<LeftArrow>,<Backspace>,<h>
ViBackwardWord
Mova o cursor de volta para o início da palavra atual ou, se entre palavras, o início da palavra anterior. Os limites do Word são definidos por um conjunto configurável de caracteres.
- Modo de comando vi:
<b>
Os caracteres que definem limites de palavra são configurados na propriedade WordDelimiters do objeto PSConsoleReadLineOptions. Para exibir ou alterar a propriedade WordDelimiters, consulte Get-PSReadLineOption e Set-PSReadLineOption.
ViForwardChar
Mova o cursor um caractere para a direita no modo de edição do Vi. Isso pode mover o cursor para a próxima linha de entrada de várias linhas.
- Modo de inserção vi:
<RightArrow> - Modo de comando Vi:
<RightArrow>,<Spacebar>,<l>
ViEndOfGlob
Move o cursor para o final da palavra, usando apenas o espaço em branco como delimitadores.
- Modo de comando vi:
<E>
ViEndOfPreviousGlob
Move-se para o final da palavra anterior, usando apenas o espaço em branco como delimitador de palavras.
- A função não está relacionada.
ViGotoBrace
Semelhante a GotoBrace, mas é baseado em caractere em vez de baseado em token.
- Modo de comando vi:
<%>
ViNextGlob
Move para a próxima palavra, usando apenas o espaço em branco como delimitador de palavras.
- Modo de comando vi:
<W>
ViNextWord
Mova o cursor para a frente até o início da próxima palavra. Os limites do Word são definidos por um conjunto configurável de caracteres.
- Modo de comando vi:
<w>
Os caracteres que definem limites de palavra são configurados na propriedade WordDelimiters do objeto PSConsoleReadLineOptions. Para exibir ou alterar a propriedade WordDelimiters, consulte Get-PSReadLineOption e Set-PSReadLineOption.
Funções de histórico
Começo da História
Mova para o primeiro item do histórico.
- Emacs:
<Alt+<>
Limpar História
Limpa o histórico no PSReadLine. Isso não afeta o histórico do PowerShell.
- Cmd:
<Alt+F7>
Fim da história
Mova para o último item (a entrada atual) no histórico.
- Emacs:
<Alt+>>
ForwardSearchHistory
Execute uma pesquisa incremental por meio do histórico.
- Cmd:
<Ctrl+s> - Emacs:
<Ctrl+s>
HistorySearchBackward
Substitua a entrada atual pelo item 'anterior' do histórico PSReadLine que corresponde aos caracteres entre o início e a entrada e o cursor.
- Cmd:
<F8>
HistóriaPesquisaEncaminhar
Substitua a entrada atual pelo item 'next' do histórico PSReadLine que corresponde aos caracteres entre o início e a entrada e o cursor.
- Cmd:
<Shift+F8>
PróximoHistória
Substitua a entrada atual pelo item 'next' do histórico PSReadLine.
- Cmd:
<DownArrow> - Emacs:
<DownArrow>,<Ctrl+n> - Modo de inserção vi:
<DownArrow> - Modo de comando Vi:
<DownArrow>,<j>,<+>
AnteriorHistória
Substitua a entrada atual pelo item 'anterior' do histórico PSReadLine.
- Cmd:
<UpArrow> - Emacs:
<UpArrow>,<Ctrl+p> - Modo de inserção vi:
<UpArrow> - Modo de comando Vi:
<UpArrow>,<k>,<->
ReverseSearchHistory
Execute uma pesquisa incremental com versões anteriores por meio do histórico.
- Cmd:
<Ctrl+r> - Emacs:
<Ctrl+r>
ViSearchHistoryBackward
Solicita uma cadeia de caracteres de pesquisa e inicia a pesquisa em AcceptLine.
- Modo de inserção vi:
<Ctrl+r> - Modo de comando Vi:
</>,<Ctrl+r>
Funções de conclusão
Completar
Tente executar a conclusão no texto ao redor do cursor. Se houver várias conclusões possíveis, o prefixo inequívoca mais longo será usado para conclusão. Se estiver tentando concluir a conclusão inequívoca mais longa, uma lista de conclusões possíveis será exibida.
- Emacs:
<Tab>
Cardápio Completo
Tente executar a conclusão no texto ao redor do cursor. Se houver várias conclusões possíveis, o prefixo inequívoca mais longo será usado para conclusão. Se estiver tentando concluir a conclusão inequívoca mais longa, uma lista de conclusões possíveis será exibida.
- Cmd:
<Ctrl+@>,<Ctrl+Spacebar> - Emacs:
<Ctrl+Spacebar>
Conclusões possíveis
Exiba a lista de conclusões possíveis.
- Emacs:
<Alt+=> - Modo de inserção vi:
<Ctrl+Spacebar> - Modo de comando vi:
<Ctrl+Spacebar>
TabCompleteNext
Tente concluir o texto em torno do cursor com a próxima conclusão disponível.
- Cmd:
<Tab> - Modo de comando vi:
<Tab>
TabCompletePrevious
Tente concluir o texto em torno do cursor com a conclusão disponível anterior.
- Cmd:
<Shift+Tab> - Modo de comando vi:
<Shift+Tab>
ViTabCompleteNext
Termina o grupo de edição atual, se necessário, e invoca TabCompleteNext.
- Modo de inserção vi:
<Tab>
ViTabCompletePrevious
Termina o grupo de edição atual, se necessário, e invoca TabCompletePrevious.
- Modo de inserção vi:
<Shift+Tab>
Funções diversas
AcceptNextSuggestionWord
Aceite a próxima palavra da sugestão embutida ou selecionada.
- A função não está relacionada.
AceitarSugestão
Aceite a sugestão embutida ou selecionada atual.
- A função não está relacionada.
Tela de captura
Inicie a captura de tela interativa – setas para cima/para baixo selecionem linhas, insira cópias de texto selecionado para área de transferência como texto e HTML.
- A função não está relacionada.
Limpar Tela
Desmarque a tela e desenhe a linha atual na parte superior da tela.
- Cmd:
<Ctrl+l> - Emacs:
<Ctrl+l> - Modo de inserção vi:
<Ctrl+l> - Modo de comando vi:
<Ctrl+l>
Argumento de dígito
Inicie um novo argumento de dígito para passar para outras funções. Você pode usá-lo como um multiplicador para a próxima função que é invocada por uma tecla. Por exemplo, pressionar <Alt+1><Alt+0> define o valor de argumento de dígito como 10. Em seguida, pressionar a tecla # envia 10 # caracteres (##########) para a linha de entrada.
Da mesma forma, você pode usá-lo com outras operações, como <Delete> ou Left-Arrow.
- Cmd:
<Alt+0>,<Alt+1>,<Alt+2>,<Alt+3><Alt+4>,<Alt+5>,<Alt+6><Alt+7><Alt+8>, ,<Alt+9><Alt+-> - Emacs:
<Alt+0>,<Alt+1>,<Alt+2>,<Alt+3><Alt+4><Alt+5><Alt+6><Alt+7><Alt+8><Alt+9>,<Alt+-> - Modo de comando Vi:
<0>,<1>,<2>,<3>,<4>,<5>,<6>,<7>,<8>,<9>
Invocar Prompt
Apaga o prompt atual e chama a função de prompt para redisplay do prompt. Útil para manipuladores de chaves personalizados que alteram o estado. Por exemplo, altere o diretório atual.
- A função não está relacionada.
ScrollDisplayDown
Role a exibição para baixo em uma tela.
- Cmd:
<PageDown> - Emacs:
<PageDown>
ScrollDisplayDownLine
Role a exibição para baixo em uma linha.
- Cmd:
<Ctrl+PageDown> - Emacs:
<Ctrl+PageDown>
ScrollDisplayToCursor
Role a exibição até o cursor.
- Emacs:
<Ctrl+End>
ScrollDisplayTop
Role a exibição até a parte superior.
- Emacs:
<Ctrl+Home>
ScrollDisplayUp
Role a tela para cima em uma tela.
- Cmd:
<PageUp> - Emacs:
<PageUp>
ScrollDisplayUpLine
Role a tela para cima em uma linha.
- Cmd:
<Ctrl+PageUp> - Emacs:
<Ctrl+PageUp>
Autoinserção
Insira a chave.
- A função não está relacionada.
ShowKeyBindings
Mostrar todas as chaves associadas.
- Cmd:
<Ctrl+Alt+?> - Emacs:
<Ctrl+Alt+?> - Modo de inserção vi:
<Ctrl+Alt+?>
Modo de comando do Vi
Alterne o modo operacional atual de Vi-Insert para Vi-Command.
- Modo de inserção vi:
<Escape>
ViDigitArgumentInChord
Inicie um novo argumento de dígito para passar para outras funções enquanto estiver em um dos acordes de vi.
- A função não está relacionada.
ViEditVisualmente
Edite a linha de comando em um editor de texto especificado por $env:EDITOR ou $env:VISUAL.
- Emacs:
<Ctrl+x,Ctrl+e> - Modo de comando vi:
<v>
Saída Vi
Sai do shell.
- A função não está relacionada.
Modo de inserção de vis
Alterne para o modo Inserir.
- Modo de comando vi:
<i>
O que é a chave
Leia uma chave e me diga ao que a chave está associada.
- Cmd:
<Alt+?> - Emacs:
<Alt+?>
Funções de seleção
ExchangePointAndMark
O cursor é colocado no local da marca e a marca é movida para o local do cursor.
- Emacs:
<Ctrl+x,Ctrl+x>
Selecionar Tudo
Selecione a linha inteira.
- Cmd:
<Ctrl+a>
SelecioneBackwardChar
Ajuste a seleção atual para incluir o caractere anterior.
- Cmd:
<Shift+LeftArrow> - Emacs:
<Shift+LeftArrow>
SelectBackwardsLine
Ajuste a seleção atual para incluir do cursor até o início da linha.
- Cmd:
<Shift+Home> - Emacs:
<Shift+Home>
SelecioneBackwardWord
Ajuste a seleção atual para incluir a palavra anterior.
- Cmd:
<Shift+Ctrl+LeftArrow> - Emacs:
<Alt+B>
SelecioneForwardChar
Ajuste a seleção atual para incluir o próximo caractere.
- Cmd:
<Shift+RightArrow> - Emacs:
<Shift+RightArrow>
SelecioneEncaminharPalavra
Ajuste a seleção atual para incluir a próxima palavra usando ForwardWord.
- Emacs:
<Alt+F>
Selecionar Linha
Ajuste a seleção atual para incluir do cursor até o final da linha.
- Cmd:
<Shift+End> - Emacs:
<Shift+End>
SelecionePróximoPalavra
Ajuste a seleção atual para incluir a próxima palavra.
- Cmd:
<Shift+Ctrl+RightArrow>
SelecioneShellBackwardWord
Ajuste a seleção atual para incluir a palavra anterior usando ShellBackwardWord.
- A função não está relacionada.
SelecioneShellForwardWord
Ajuste a seleção atual para incluir a próxima palavra usando ShellForwardWord.
- A função não está relacionada.
SelecioneShellPróximoWord
Ajuste a seleção atual para incluir a próxima palavra usando ShellNextWord.
- A função não está relacionada.
Marca do conjunto
Marque o local atual do cursor para uso em um comando de edição subsequente.
- Emacs:
<Ctrl+@>
Funções preditivas do IntelliSense
Nota
O IntelliSense preditivo precisa ser habilitado para usar essas funções.
AcceptNextWordSuggestion
Aceita a próxima palavra da sugestão embutida do Predictive IntelliSense. Essa função pode ser vinculada com Ctrl+F executando o comando a seguir.
Set-PSReadLineKeyHandler -Chord "Ctrl+f" -Function ForwardWord
AceitarSugestão
Aceita a sugestão embutida atual do IntelliSense Preditivo pressionando Seta para a direita quando o cursor está no final da linha atual.
Funções de pesquisa
Pesquisa de Personagens
Leia um caractere e pesquise a próxima ocorrência desse caractere. Se um argumento for especificado, pesquise para frente (ou para trás, se negativo) para a nª ocorrência.
- Cmd:
<F3> - Emacs:
<Ctrl+]> - Modo de inserção vi:
<F3> - Modo de comando vi:
<F3>
PersonagemPesquisaBackward
Leia um caractere e pesquise para trás a próxima ocorrência desse caractere. Se um argumento for especificado, pesquise para trás (ou para frente, se negativo) para a nª ocorrência.
- Cmd:
<Shift+F3> - Emacs:
<Ctrl+Alt+]> - Modo de inserção vi:
<Shift+F3> - Modo de comando vi:
<Shift+F3>
RepeatLastCharSearch
Repita a última pesquisa de caracteres gravada.
- Modo de comando vi:
<;>
RepeatLastCharSearchBackwards
Repita a última pesquisa de caracteres gravada, mas na direção oposta.
- Modo de comando vi:
<,>
Repetir Pesquisa
Repita a última pesquisa na mesma direção de antes.
- Modo de comando vi:
<n>
RepeatSearchBackward
Repita a última pesquisa na mesma direção de antes.
- Modo de comando vi:
<N>
SearchChar
Leia o próximo caractere e, em seguida, encontre-o, daqui para frente e, em seguida, retire um caractere. Isso é para a funcionalidade 't'.
- Modo de comando vi:
<f>
ProcurarCharBackward
Leia o próximo caractere e, em seguida, localize-o, indo para trás e, em seguida, desative um caractere. Isso é para a funcionalidade 'T'.
- Modo de comando vi:
<F>
SearchCharBackwardWithBackoff
Leia o próximo caractere e, em seguida, localize-o, indo para trás e, em seguida, desative um caractere. Isso é para a funcionalidade 'T'.
- Modo de comando vi:
<T>
SearchCharWithBackoff
Leia o próximo caractere e, em seguida, encontre-o, daqui para frente e, em seguida, retire um caractere. Isso é para a funcionalidade 't'.
- Modo de comando vi:
<t>
Pesquisar para a frente
Solicita uma cadeia de caracteres de pesquisa e inicia a pesquisa em AcceptLine.
- Modo de inserção vi:
<Ctrl+s> - Modo de comando Vi:
<?>,<Ctrl+s>
Associações de chave personalizadas
PSReadLine oferece suporte a associações de teclas personalizadas usando o cmdlet Set-PSReadLineKeyHandler. A maioria das associações de chave personalizadas chama uma das funções acima, por exemplo
Set-PSReadLineKeyHandler -Key UpArrow -Function HistorySearchBackward
Você pode associar um ScriptBlock a uma chave. O ScriptBlock pode fazer praticamente tudo o que você quiser. Alguns exemplos úteis incluem
- editar a linha de comando
- abrindo uma nova janela (por exemplo, ajuda)
- alterar diretórios sem alterar a linha de comando
O ScriptBlock recebe dois argumentos:
$key- Um objeto [ConsoleKeyInfo] que é a chave que disparou a associação personalizada. Se você associar o mesmo ScriptBlock a várias chaves e precisar executar ações diferentes dependendo da chave, poderá verificar $key. Muitas associações personalizadas ignoram esse argumento.$arg- Um argumento arbitrário. Na maioria das vezes, esse seria um argumento inteiro que o usuário passa das associações de chave DigitArgument. Se a associação não aceitar argumentos, é razoável ignorar esse argumento.
Vamos dar uma olhada em um exemplo que adiciona uma linha de comando ao histórico sem executá-la. Isso é útil quando você percebe que esqueceu de fazer algo, mas não quer inserir novamente a linha de comando que você já inseriu.
$parameters = @{
Key = 'Alt+w'
BriefDescription = 'SaveInHistory'
LongDescription = 'Save current line in history but do not execute'
ScriptBlock = {
param($key, $arg) # The arguments are ignored in this example
# GetBufferState gives us the command line (with the cursor position)
$line = $null
$cursor = $null
[Microsoft.PowerShell.PSConsoleReadLine]::GetBufferState([ref]$line,
[ref]$cursor)
# AddToHistory saves the line in history, but does not execute it.
[Microsoft.PowerShell.PSConsoleReadLine]::AddToHistory($line)
# RevertLine is like pressing Escape.
[Microsoft.PowerShell.PSConsoleReadLine]::RevertLine()
}
}
Set-PSReadLineKeyHandler @parameters
Você pode ver muitos outros exemplos no arquivo SamplePSReadLineProfile.ps1 que está instalado na pasta do módulo PSReadLine.
A maioria das associações de chave usa algumas funções auxiliares para editar a linha de comando. Essas APIs estão documentadas na próxima seção.
APIs de suporte de associação de chave personalizada
As funções a seguir são públicas em Microsoft.PowerShell.PSConsoleReadLine, mas não podem ser diretamente associadas a uma chave. A maioria é útil em associações de chave personalizadas.
void AddToHistory(string command)
Adicione uma linha de comando ao histórico sem executá-la.
void ClearKillRing()
Desmarque o anel de morte. Isso é usado principalmente para testes.
void Delete(int start, int length)
Exclua caracteres de comprimento desde o início. Essa operação dá suporte a desfazer/refazer.
void Ding()
Execute a ação Ding com base na preferência dos usuários.
void GetBufferState([ref] string input, [ref] int cursor)
void GetBufferState([ref] Ast ast, [ref] Token[] tokens,
[ref] ParseError[] parseErrors, [ref] int cursor)
Essas duas funções recuperam informações úteis sobre o estado atual do buffer de entrada. O primeiro é mais comumente usado para casos simples. O segundo será usado se a associação estiver fazendo algo mais avançado com o Ast.
IEnumerable[Microsoft.PowerShell.KeyHandler]
GetKeyHandlers(bool includeBound, bool includeUnbound)
IEnumerable[Microsoft.PowerShell.KeyHandler]
GetKeyHandlers(string[] Chord)
Essas duas funções são usadas por Get-PSReadLineKeyHandler. O primeiro é usado para obter todas as associações de chave. O segundo é usado para obter associações de chave específicas.
Microsoft.PowerShell.PSConsoleReadLineOptions GetOptions()
Essa função é usada por Get-PSReadLineOption e provavelmente não é muito útil em uma associação de chave personalizada.
void GetSelectionState([ref] int start, [ref] int length)
Se não houver seleção na linha de comando, a função retornará -1 em início e comprimento. Se houver uma seleção na linha de comando, o início e o comprimento da seleção serão retornados.
void Insert(char c)
void Insert(string s)
Insira um caractere ou cadeia de caracteres no cursor. Essa operação dá suporte a desfazer/refazer.
string ReadLine(runspace remoteRunspace,
System.Management.Automation.EngineIntrinsics engineIntrinsics)
Esse é o ponto de entrada principal para PSReadLine. Ele não dá suporte à recursão, portanto, não é útil em uma associação de chave personalizada.
void RemoveKeyHandler(string[] key)
Essa função é usada por Remove-PSReadLineKeyHandler e provavelmente não é muito útil em uma associação de chave personalizada.
void Replace(int start, int length, string replacement)
Substitua parte da entrada. Essa operação dá suporte a desfazer/refazer. Isso é preferencial em vez de Excluir seguido por Inserir porque é tratado como uma única ação para desfazer.
void SetCursorPosition(int cursor)
Mova o cursor para o deslocamento fornecido. O movimento do cursor não é controlado para desfazer.
void SetOptions(Microsoft.PowerShell.SetPSReadLineOption options)
Essa função é um método auxiliar usado pelo cmdlet Set-PSReadLineOption, mas pode ser útil para uma associação de chave personalizada que deseja alterar temporariamente uma configuração.
bool TryGetArgAsInt(System.Object arg, [ref] int numericArg,
int defaultNumericArg)
Esse método auxiliar é usado para associações personalizadas que respeitam o DigitArgument. Uma chamada típica se parece com
[int]$numericArg = 0
[Microsoft.PowerShell.PSConsoleReadLine]::TryGetArgAsInt($arg,
[ref]$numericArg, 1)
Anotações
Histórico de comandos
O PSReadLine mantém um arquivo de histórico que contém todos os comandos e dados inseridos na linha de comando. Os arquivos de histórico são um arquivo chamado $($host.Name)_history.txt. Em sistemas Windows, o arquivo de histórico é armazenado em $env:APPDATA\Microsoft\Windows\PowerShell\PSReadLine. Em sistemas não Windows, os arquivos de histórico são armazenados em $env:XDG_DATA_HOME/powershell/PSReadLine ou $env:HOME/.local/share/powershell/PSReadLine.
O histórico pode conter dados confidenciais, incluindo senhas. O PSReadLine tenta filtrar informações confidenciais. Todas as linhas de comando que contêm as cadeias de caracteres a seguir não são gravadas no arquivo de histórico.
- senha
- texto simples
- símbolo
- Chave de API
- segredo
Feedback e Contribuição para o PSReadLine
Fique à vontade para enviar uma solicitação pull ou enviar comentários na página do GitHub.
Consulte Também
- O PSReadLine é fortemente influenciado pelo GNU biblioteca de de linha de leitura.