Partilhar via


about_PSReadLine_Functions

Short Description

PSReadLine fornece uma experiência de edição de linha de comando aprimorada no console do PowerShell.

Descrição longa

O PowerShell 7.3 é fornecido com PSReadLine 2.2.6. A versão atual é PSReadLine 2.3.4. A versão atual do PSReadLine pode ser instalada e usada no Windows PowerShell 5.1 e mais recente. Para alguns recursos, você precisa estar executando o PowerShell 7.2 ou superior.

Este artigo documenta as funções fornecidas pelo PSReadLine 2.3.4. Essas funções podem ser vinculadas a pressionamentos de teclas para facilitar o acesso e a invocação.

Usando a classe Microsoft.PowerShell.PSConsoleReadLine

As funções a seguir estão disponíveis na classe Microsoft.PowerShell.PSConsoleReadLine.

Funções básicas de edição

Abortar

Anular a ação atual, por exemplo: pesquisa incremental do histórico.

  • Modo Emacs: Ctrl+g
  • Vi modo de inserção: Ctrl+g
  • Modo de comando Vi: <Ctrl+g>

AcceptAndGetNext

Tente executar a entrada atual. Se puder ser executado (como AcceptLine), recupere o próximo item do histórico na próxima vez que ReadLine for chamado.

  • Modo Emacs: Ctrl+o

AcceptLine

Tente executar a entrada atual. Se a entrada atual estiver incompleta (por exemplo, há um parêntese de fechamento, colchete ou cotação ausente), o prompt de continuação será exibido na próxima linha e PSReadLine aguardará as chaves para editar a entrada atual.

  • Modo Windows: Enter
  • Modo Emacs: Enter
  • Vi modo de inserção: Enter

AddLine

O prompt de continuação é exibido na próxima linha e PSReadLine aguarda as 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 é uma entrada completa por si só.

  • Modo Windows: Shift+Enter
  • Modo Emacs: Shift+Enter
  • Vi modo de inserção: Shift+Enter
  • Modo de comando Vi: <Shift+Enter>

BackwardDeleteChar

Exclua o caractere antes do cursor.

  • Modo Windows: Backspace, Ctrl+h
  • Modo Emacs: Backspace, Ctrl+Backspace, Ctrl+h
  • Vi modo de inserção: Backspace
  • Modo de comando Vi: <X>, <d,h>

BackwardDeleteInput

Como BackwardKillInput - exclui o texto do ponto para o início da entrada, mas não coloca o texto excluído no anel de morte.

  • Modo Windows: Ctrl+Home
  • Vi modo de inserção: Ctrl+u, Ctrl+Home
  • Modo de comando Vi: <Ctrl+u>, <Ctrl+Home>

BackwardDeleteLine

Como BackwardKillLine - exclui o texto do ponto para o início da linha, mas não coloca o texto excluído no anel de morte.

  • Modo de comando Vi: <d,0>

BackwardDeleteWord

Exclui a palavra anterior.

  • Modo de comando Vi: <Ctrl+w>, <d,b>

BackwardKillInput

Limpe o texto desde o início da entrada até o cursor. O texto limpo é colocado no anel de morte.

  • Modo Emacs: Ctrl+u, Ctrl+x,Backspace

BackwardKillLine

Limpe o texto do início da linha lógica atual para o cursor. O texto limpo é colocado no anel de morte.

  • A função não está vinculada.

BackwardKillWord

Limpe a entrada do início da palavra atual para o cursor. Se o cursor estiver entre palavras, a entrada é limpa do início da palavra anterior para o cursor. O texto limpo é colocado no anel de morte.

  • Modo Windows: Ctrl+Backspace, Ctrl+w
  • Modo Emacs: Alt+Backspace, Escape,Backspace
  • Vi modo de inserção: Ctrl+Backspace
  • Modo de comando Vi: <Ctrl+Backspace>

BackwardReplaceChar

Substitui o caractere na frente do cursor.

  • Modo de comando Vi: <c,h>

CancelLine

Cancele a entrada atual, deixando a entrada na tela, mas retorna ao host para que o prompt seja avaliado novamente.

  • Vi modo de inserção: Ctrl+c
  • Modo de comando Vi: <Ctrl+c>

CapitalizeWord

Adicionado em PSReadLine 2.3.0

Converta o primeiro caractere da próxima palavra em maiúsculas e os caracteres restantes em minúsculas.

  • Modo Emacs: Alt+c, Escape,c

Copiar

Copie a região selecionada para a área de transferência do sistema. Se nenhuma região for selecionada, copie a linha inteira.

  • Modo Windows: Ctrl+C

CopyOrCancelLine

Se o texto estiver selecionado, copie para a área de transferência, caso contrário, cancele a linha.

  • Modo Windows: Ctrl+c
  • Modo Emacs: Ctrl+c

Cortar

Exclua a região selecionada colocando texto excluído na área de transferência do sistema.

  • Modo Windows: Ctrl+x

DeleteChar

Exclua o caractere sob o cursor.

  • Modo Windows: Delete
  • Modo Emacs: Delete
  • Vi modo de inserção: Delete
  • Vi modo de comando: <Delete>, <x>, <d,l>, , <d,Spacebar>

DeleteCharOrExit

Exclua o caractere sob o cursor ou, se a linha estiver vazia, saia do processo.

  • Modo Emacs: Ctrl+d

DeleteEndOfBuffer

Exclui até o final do buffer de várias linhas.

  • Modo de comando Vi: <d,G>

DeleteEndOfWord

Eliminar até ao final da palavra.

  • Modo de comando Vi: <d,e>

DeleteLine

Exclui a linha lógica atual de um buffer de várias linhas, permitindo desfazer.

  • Modo de comando Vi: <d,d>, <d,_>

DeleteLineToFirstChar

Exclui do primeiro caractere não em branco da linha lógica atual em um buffer de várias linhas.

  • Modo de comando Vi: <d,^>

DeleteNextLines

Exclui as linhas lógicas n atuais e seguintes em um buffer de várias linhas.

  • Modo de comando Vi: <d,j>

DeletePreviousLines

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>

DeleteRelativeLines

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 <d,g,g> comando pode ser precedido de 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 assume como padrão 1, que se refere à primeira linha lógica em um buffer de várias linhas.

O número real de linhas a serem excluídas da linha múltipla é calculado como a diferença entre o número da linha lógica atual e o argumento numérico especificado, que pode, portanto, ser negativo. Daí a parte relativa do nome do método.

  • Modo de comando Vi: <d,g,g>

DeleteToEnd

Exclua até o final da linha.

  • Modo de comando Vi: <D>, <d,$>

ExcluirWord

Elimine a palavra seguinte.

  • Modo de comando Vi: <d,w>

DowncaseWord

Adicionado em PSReadLine 2.3.0

Converta a próxima palavra em minúsculas.

  • Modo Emacs: Alt+l, Escape,l

ForwardDeleteInput

Como KillLine - exclui o texto do ponto para o final da entrada, mas não coloca o texto excluído no anel de morte.

  • Modo Windows: Ctrl+End
  • Vi modo de inserção: Ctrl+End
  • Modo de comando Vi: <Ctrl+End>

ForwardDeleteLine

Exclui o texto do ponto até o final da linha lógica atual, mas não coloca o texto excluído no anel de eliminação.

  • A função não está vinculada

InsertLineAbove

Uma nova linha vazia é criada acima da linha atual, independentemente de onde o cursor esteja na linha atual. O cursor se move para o início da nova linha.

  • Modo Windows: Ctrl+Enter

InsertLineBelow

Uma nova linha vazia é criada abaixo da linha atual, independentemente de onde o cursor esteja na linha atual. O cursor se move para o início da nova linha.

  • Modo Windows: Shift+Ctrl+Enter

InvertCase

Inverta o caso do caractere atual e passe para o próximo.

  • Modo de comando Vi: <~>

KillLine

Limpe a entrada do cursor para o final da entrada. O texto limpo é colocado no anel de morte.

  • Modo Emacs: Ctrl+k

KillRegion

Mate o texto entre o cursor e a marca.

  • A função não está vinculada.

KillWord

Limpe a entrada do cursor até o final da palavra atual. Se o cursor estiver entre palavras, a entrada será limpa do cursor até o final da próxima palavra. O texto limpo é colocado no anel de morte.

  • Modo Windows: Alt+d, Ctrl+Delete
  • Modo Emacs: Alt+d, Escape,d
  • Vi modo de inserção: Ctrl+Delete
  • Modo de comando Vi: <Ctrl+Delete>

Colar

Cole o texto da área de transferência do sistema.

  • Modo Windows: Ctrl+v, Shift+Insert
  • Vi modo de inserção: 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. O buffer de entrada é então passado para o analisador do PowerShell. A entrada colada usando o método de colar do botão direito do mouse do aplicativo de console é 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 os métodos de colagem resulta em um comportamento de execução diferente.

ColarDepois

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

Insira um '#' e aceite a linha.

  • Modo de comando Vi: <#>

Refazer

Desfazer um desfazer.

  • Modo Windows: Ctrl+y
  • Vi modo de inserção: Ctrl+y
  • Modo de comando Vi: <Ctrl+y>

RepeatLastCommand

Repita a última modificação de texto.

  • Modo de comando Vi: <.>

ReplaceChar

Substitua o caractere atual pelo próximo conjunto de caracteres digitados.

  • Modo de comando Vi: <c,l>, <c,Spacebar>

SubstituirCharInPlace

Substitua o caractere atual por apenas um caractere.

  • Modo de comando Vi: <r>

RevertLine

Reverte toda a entrada para a entrada atual.

  • Modo Windows: Escape
  • Modo Emacs: Alt+r, Escape,r

ShellBackwardKillWord

Limpe a entrada do início da palavra atual para o cursor. Se o cursor estiver entre palavras, a entrada é limpa do início da palavra anterior para o cursor. O texto limpo é colocado no anel de morte.

A função não está vinculada.

ShellKillWord

Limpe a entrada do cursor até o final da palavra atual. Se o cursor estiver entre palavras, a entrada será limpa do cursor até o final da próxima palavra. O texto limpo é colocado no anel de morte.

A função não está vinculada.

Caracteres Swap

Troque o caractere atual pelo anterior.

  • Modo Emacs: Ctrl+t
  • Vi modo de inserção: Ctrl+t
  • Modo de comando Vi: <Ctrl+t>

Anular

Desfazer uma edição anterior.

  • Modo Windows: Ctrl+z
  • Modo Emacs: Ctrl+_, Ctrl+x,Ctrl+u
  • Vi modo de inserção: Ctrl+z
  • Modo de comando Vi: <Ctrl+z>, <u>

Desfazer tudo

Desfaça todas as edições anteriores da linha.

  • Modo de comando Vi: <U>

UnixWordRubout

Limpe a entrada do início da palavra atual para o cursor. Se o cursor estiver entre palavras, a entrada é limpa do início da palavra anterior para o cursor. O texto limpo é colocado no anel de morte.

  • Modo Emacs: Ctrl+w

UpcaseWord

Adicionado em PSReadLine 2.3.0

Converta a próxima palavra em maiúsculas.

  • Modo Emacs: Alt+u, Escape,u

ValidateAndAcceptLine

Tente executar a entrada atual. Se a entrada atual estiver incompleta (por exemplo, há um parêntese de fechamento, colchete ou cotação ausente), o prompt de continuação será exibido na próxima linha e PSReadLine aguardará as chaves para editar a entrada atual.

  • Modo Emacs: Ctrl+m

ViAcceptLine

Aceite a linha e mude 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.

  • Vi modo de inserção: 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 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 espaço em branco como delimitadores.

  • Modo de comando Vi: <B>

ViBackwardReplaceGlob

Exclua para trás para o início da palavra anterior, conforme delimitado por espaço em branco, e digite o modo de inserção.

  • Modo de comando Vi: <c,B>

ViBackwardReplaceLine

Substitui a linha esquerda do cursor e todo o caminho até o início.

  • Modo de comando Vi: <c,0>

ViBackwardReplaceLineToFirstChar

Substitui a linha esquerda do cursor e todos os caracteres, exceto um, no início da linha.

  • Modo de comando Vi: <c,^>

ViBackwardReplaceWord

Substitua a palavra anterior.

  • Modo de comando Vi: <c,B>

ViDeleteBrace

Encontre a chave, parêntese ou colchete correspondente e exclua todo o conteúdo contido, incluindo a chave.

  • Modo de comando Vi: <d,%>

ViDeleteEndOfGlob

Eliminar até ao 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

Mude para o modo Inserir e posicione o cursor no início da linha.

  • Modo de comando Vi: <I>

ViInsertAtEnd

Mude 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

Acrescentar a partir 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

Junta-se à linha atual e à linha seguinte.

  • Modo de comando Vi: <J>

ViReplaceBrace

Substitua todos os caracteres entre o caractere de chave atual e seu parceiro correspondente.

  • Modo de comando Vi: <c,%>

ViReplaceEndOfGlob

Exclua até o final da palavra, conforme delimitado por espaço em branco, e digite o modo de inserção.

  • Modo de comando Vi: <c,E>

ViReplaceEndOfWord

Exclua até o final da palavra, conforme delimitado por espaço em branco e delimitadores comuns, e entre no modo de inserção.

  • Modo de comando Vi: <c,E>

ViReplaceGlob

Exclua para o início da próxima palavra, conforme delimitado por espaço em branco, e digite o modo de inserção.

  • Modo de comando Vi: <c,W>

ViReplaceLine

Apague toda a linha de comando.

  • Modo de comando Vi: <S>, <c,c>

ViReplaceToBeforeChar

Substitui até determinado caráter.

  • Modo de comando Vi: <c,t>

ViReplaceToBeforeCharBackward

Substitui até determinado caráter.

  • Modo de comando Vi: <c,T>

ViReplaceToChar

Exclui até determinado caractere.

  • Modo de comando Vi: <c,f>

ViReplaceToCharBackward

Substitui até determinado caráter.

  • Modo de comando Vi: <c,F>

ViReplaceToEnd

Substitua os caracteres da posição do cursor até o final da linha.

  • Modo de comando Vi: <c,$>, <C>

ViReplaceUntilEsc

Substitua o caractere atual até que uma fuga seja inserida ou a linha seja aceita.

  • Modo de comando Vi: <r>

ViReplaceWord

Substitua a palavra atual.

  • Modo de comando Vi: <c,W>

ViYankBeginningOfLine

Yank do início do buffer para o cursor.

  • Modo de comando Vi: <y,0>

ViYankEndOfGlob

Puxe do cursor para o final da(s) PALAVRA(s).

  • Modo de comando Vi: <y,E>

ViYankEndOfWord

Passe do cursor para o final da(s) palavra(s).

  • Modo de comando Vi: <y,e>

ViYankEsquerda

Caractere(s) Yank à esquerda do cursor.

  • Modo de comando Vi: <y,h>

ViYankLine

Yank todo o buffer.

  • Modo de comando Vi: <y,y>

ViYankNextGlob

Passe do cursor para o início da(s) próxima(s) PALAVRA(s).

  • Modo de comando Vi: <y,W>

ViYankPróximoWord

Passe a(s) palavra(s) após o cursor.

  • Modo de comando Vi: <y,w>

ViYankPercent

Yank para/de chave correspondente.

  • Modo de comando Vi: <y,%>

ViYankPreviousGlob

Passe do início da(s) PALAVRA(s) para o cursor.

  • Modo de comando Vi: <y,B>

ViYankAnteriorWord

Aperte a(s) palavra(s) antes do cursor.

  • Modo de comando Vi: <y,b>

ViYankRight

Caractere(s) Yank(s) sob e à direita do cursor.

  • Modo de comando Vi: <y,l>, <y,Spacebar>

ViYankToEndOfLine

Passe do cursor para o final do buffer.

  • Modo de comando Vi: <y,$>

ViYankToFirstChar

Passe do primeiro caractere sem espaço em branco para o cursor.

  • Modo de comando Vi: <y,^>

Yank

Adicione o texto morto mais recentemente à entrada.

  • Modo Emacs: Ctrl+y

YankLastArg

Yank o último argumento da linha da história anterior. Com um argumento, a primeira vez que é invocado, comporta-se como YankNthArg. Se invocado várias vezes, em vez disso, ele itera através do histórico e arg define a direção (negativo inverte a direção.)

  • Modo Windows: Alt+.
  • Modo Emacs: Alt+., Alt+_, Escape,., Escape,_

YankNthArg

Tire o primeiro argumento (após o comando) da linha do histórico anterior. Com um argumento, puxe o nono argumento (a partir de 0), se o argumento for negativo, comece a partir do último argumento.

  • Modo Emacs: Ctrl+Alt+y, Escape,Ctrl+y

YankPop

Se a operação anterior foi Yank ou YankPop, substitua o texto previamente arrancado pelo próximo texto morto do anel de morte.

  • Modo Emacs: Alt+y, Escape,y

Funções de conclusão

Concluído

Tente executar a conclusão no texto ao redor do cursor. Se houver várias completações possíveis, o prefixo inequívoco mais longo é usado para conclusão. Se tentar concluir a conclusão inequívoca mais longa, será exibida uma lista de possíveis conclusão.

  • Modo Emacs: Tab

Tente executar a conclusão no texto ao redor do cursor. Se houver várias completações possíveis, o prefixo inequívoco mais longo é usado para conclusão. Se tentar concluir a conclusão inequívoca mais longa, será exibida uma lista de possíveis conclusão.

  • Modo Windows: Ctrl+@, Ctrl+Spacebar
  • Modo Emacs: Ctrl+Spacebar

Possíveis Finalizações

Exiba a lista de possíveis conclusãos.

  • Modo Emacs: Alt+=
  • Vi modo de inserção: Ctrl+Spacebar
  • Modo de comando Vi: <Ctrl+Spacebar>

TabCompleteNext

Tente completar o texto ao redor do cursor com a próxima conclusão disponível.

  • Modo Windows: Tab
  • Modo de comando Vi: <Tab>

TabCompletePrevious

Tente completar o texto ao redor do cursor com a conclusão disponível anterior.

  • Modo Windows: Shift+Tab
  • Modo de comando Vi: <Shift+Tab>

ViTabCompleteNext

Encerra o grupo de edição atual, se necessário, e invoca TabCompleteNext.

  • Vi modo de inserção: Tab

ViTabCompletePrevious

Encerra o grupo de edição atual, se necessário, e invoca TabCompletePrevious.

  • Vi modo de inserção: Shift+Tab

Funções de movimento do cursor

Retrocesso

Mova o cursor um caractere para a esquerda. Isso pode mover o cursor para a linha anterior de entrada de várias linhas.

  • Modo Windows: LeftArrow
  • Modo Emacs: LeftArrow, Ctrl+b

Palavras para trás

Mova o cursor de volta para o início da palavra atual ou, se entre palavras, para o início da palavra anterior. Os limites das palavras são definidos por um conjunto configurável de caracteres.

  • Modo Windows: Ctrl+LeftArrow
  • Modo Emacs: Alt+b, Escape,b
  • Vi modo de inserção: Ctrl+LeftArrow
  • Modo de comando Vi: <Ctrl+LeftArrow>

Os caracteres que definem limites de palavras são configurados na propriedade WordDelimiters do objeto PSConsoleReadLineOptions . Para exibir ou alterar a propriedade WordDelimiters , consulte Get-PSReadLineOption e Set-PSReadLineOption.

IníciodeLinha

Se a entrada tiver várias linhas, mova para o início da linha atual ou, se já estiver no início da linha, mova para o início da entrada. Se a entrada tiver uma única linha, mova para o início da entrada.

  • Modo Windows: Home
  • Modo Emacs: Home, Ctrl+a
  • Vi modo de inserção: Home
  • Modo de comando Vi: <Home>

Fim de linha

Se a entrada tiver várias linhas, mova para o final da linha atual ou, se já estiver no final da linha, mova para o final da entrada. Se a entrada tiver uma única linha, mova para o final da entrada.

  • Modo Windows: End
  • Modo Emacs: End, Ctrl+e
  • Vi modo de inserção: 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.

  • Modo Windows: RightArrow
  • Modo Emacs: RightArrow, Ctrl+f

ForwardWord

Mova o cursor para a frente até o final da palavra atual ou, se entre palavras, até o final da próxima palavra. Os limites das palavras são definidos por um conjunto configurável de caracteres.

  • Modo Emacs: Alt+f, Escape,f

Os caracteres que definem limites de palavras são configurados na propriedade WordDelimiters do objeto PSConsoleReadLineOptions . Para exibir ou alterar a propriedade WordDelimiters , consulte Get-PSReadLineOption e Set-PSReadLineOption.

GotoBrace

Vá para a chave, parêntese ou colchete correspondente.

  • Modo Windows: Ctrl+]
  • Vi modo de inserção: Ctrl+]
  • Modo de comando Vi: <Ctrl+]>

GotoColuna

Mover para a coluna indicada por arg.

  • Modo de comando Vi: <|>

GotoFirstNonBlankOfLine

Mova o cursor para o primeiro caractere não vazio na linha.

  • Modo de comando Vi: <^>, <_>

MoveToEndOfLine

Mova o cursor para o final da entrada.

  • Modo de comando Vi: <End>, <$>

MoveToFirstLine

Vá para a primeira linha em um comando multilinha.

  • Modo de comando Vi: <g,g>

MoveToLastLine

Vá para a última linha em um comando multilinha.

  • Modo de comando Vi: <G>

Próxima Linha

Mova o cursor para a próxima linha.

  • A função não está vinculada.

PróximoWord

Mova o cursor para a frente até o início da próxima palavra. Os limites das palavras são definidos por um conjunto configurável de caracteres.

  • Modo Windows: Ctrl+RightArrow
  • Vi modo de inserção: Ctrl+RightArrow
  • Modo de comando Vi: <Ctrl+RightArrow>

Os caracteres que definem limites de palavras são configurados na propriedade WordDelimiters do objeto PSConsoleReadLineOptions . Para exibir ou alterar a propriedade WordDelimiters , consulte Get-PSReadLineOption e Set-PSReadLineOption.

PróximoWordEnd

Mova o cursor para a frente até o final da palavra atual ou, se entre palavras, até o final da próxima palavra. Os limites das palavras são definidos por um conjunto configurável de caracteres.

  • Modo de comando Vi: <e>

Os caracteres que definem limites de palavras são configurados na propriedade WordDelimiters do objeto PSConsoleReadLineOptions . Para exibir ou alterar a propriedade WordDelimiters , consulte Get-PSReadLineOption e Set-PSReadLineOption.

AnteriorLinha

Mova o cursor para a linha anterior.

  • A função não está vinculada.

ShellBackwardWord

Mova o cursor de volta para o início da palavra atual ou, se entre palavras, para o início da palavra anterior. Os limites do Word são definidos por tokens do PowerShell.

  • A função não está vinculada.

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á vinculada.

ShellNextWord

Mova o cursor para a frente até o final da palavra atual ou, se entre palavras, até o final da próxima palavra. Os limites do Word são definidos por tokens do PowerShell.

  • A função não está vinculada.

ViBackwardChar

Mova o cursor um caractere para a esquerda no modo de edição Vi. Isso pode mover o cursor para a linha anterior de entrada de várias linhas.

  • Vi modo de inserção: 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, para o início da palavra anterior. Os limites das palavras são definidos por um conjunto configurável de caracteres.

  • Modo de comando Vi: <b>

Os caracteres que definem limites de palavras são configurados na propriedade WordDelimiters do objeto PSConsoleReadLineOptions . Para exibir ou alterar a propriedade WordDelimiters , consulte Get-PSReadLineOption e Set-PSReadLineOption.

ViEndOfGlob

Mova o cursor para o final desta palavra, conforme delimitado por espaço em branco.

  • Modo de comando Vi: <E>

ViEndOfPreviousGlob

Move para o final da palavra anterior, usando apenas espaço em branco como um delimitador de palavras.

  • A função não está vinculada.

ViForwardChar

Mova o cursor um caractere para a direita no modo de edição Vi. Isso pode mover o cursor para a próxima linha de entrada de várias linhas.

  • Vi modo de inserção: RightArrow
  • Modo de comando Vi: <RightArrow>, <Spacebar>, <l>

ViGotoBrace

Semelhante ao GotoBrace, mas é baseado em caracteres em vez de token.

  • Modo de comando Vi: <%>

ViNextGlob

Move para a próxima palavra, usando apenas espaço em branco como um 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 das palavras são definidos por um conjunto configurável de caracteres.

  • Modo de comando Vi: <w>

Os caracteres que definem limites de palavras 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

Início da História

Mover para o primeiro item do histórico.

  • Modo Emacs: Alt+<

Limpar História

Limpa o histórico no PSReadLine. Isso não afeta o histórico do PowerShell.

  • Modo Windows: Alt+F7

Fim da História

Mover para o último item (a entrada atual) no histórico.

  • Modo Emacs: Alt+>

ForwardSearchHistory

Execute uma pesquisa direta incremental através do histórico.

  • Modo Windows: Ctrl+s
  • Modo Emacs: Ctrl+s
  • Vi modo de inserção: Ctrl+s
  • Modo de comando Vi: <Ctrl+s>

HistóricoSearchBackward

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.

  • Modo Windows: F8

HistóricoSearchForward

Substitua a entrada atual pelo item 'próximo' do histórico PSReadLine que corresponde aos caracteres entre o início e a entrada e o cursor.

  • Modo Windows: Shift+F8

PróximoHistória

Substitua a entrada atual pelo item 'próximo' do histórico PSReadLine.

  • Modo Windows: DownArrow
  • Modo Emacs: DownArrow, Ctrl+n
  • Vi modo de inserção: DownArrow
  • Modo de comando Vi: <DownArrow>, <j>, <+>

AnteriorHistória

Substitua a entrada atual pelo item 'anterior' do histórico PSReadLine.

  • Modo Windows: UpArrow
  • Modo Emacs: UpArrow, Ctrl+p
  • Vi modo de inserção: UpArrow
  • Modo de comando Vi: <UpArrow>, <k>, <->

ReverseSearchHistory

Execute uma pesquisa retroativa incremental através do histórico.

  • Modo Windows: Ctrl+r
  • Modo Emacs: Ctrl+r
  • Vi modo de inserção: Ctrl+r
  • Modo de comando Vi: <Ctrl+r>

ViSearchHistoryBackward

Solicita uma cadeia de caracteres de pesquisa e inicia a pesquisa em AcceptLine.

  • Modo de comando Vi: </>

Funções diversas

Tela de captura

Inicie a captura de tela interativa - setas para cima/para baixo, selecione linhas, insira cópias do texto selecionado para a área de transferência como texto e HTML.

  • A função não está vinculada.

Ecrã Limpo

Limpe a tela e desenhe a linha atual na parte superior da tela.

  • Modo Windows: Ctrl+l
  • Modo Emacs: Ctrl+l
  • Vi modo de inserção: Ctrl+l
  • Modo de comando Vi: <Ctrl+l>

DigitArgument

Inicie um novo argumento de dígito para passar para outras funções. Você pode usar isso como um multiplicador para a próxima função que é invocada por um pressionamento de tecla. Por exemplo, pressionar <Alt+1> <Alt+0> define o valor do argumento dígito como 10. Em seguida, pressionar a # tecla envia 10 # caracteres (##########) para a linha de entrada. Da mesma forma, você pode usar isso com outras operações, como <Delete> ou Left-Arrow.

  • Modo Windows: Alt+0, Alt+1, Alt+2, Alt+3, Alt+4, Alt+5, , Alt+6, Alt+8Alt+7, , Alt+9,Alt+-
  • Modo Emacs: Alt+0, Alt+1, Alt+2, , Alt+3, Alt+4, Alt+6Alt+5, , Alt+7, Alt+8, Alt+9Alt+-
  • Modo de comando Vi: <0>, <1>, <2>, <3>, , <4>, <6><5>, , <7>, <8>,<9>

InvokePrompt

Apaga o prompt atual e chama a função prompt para exibir novamente o prompt. Útil para manipuladores de chaves personalizados que mudam de estado. Por exemplo, altere o diretório atual.

  • A função não está vinculada.

ScrollDisplayDown

Role a tela para baixo em uma tela.

  • Modo Windows: PageDown
  • Modo Emacs: PageDown

ScrollDisplayDownLine

Desloque o ecrã uma linha para baixo.

  • Modo Windows: Ctrl+PageDown
  • Modo Emacs: Ctrl+PageDown

ScrollDisplayToCursor

Desloque o ecrã para o cursor.

  • Modo Emacs: Ctrl+End

ScrollDisplayTopo

Desloque o ecrã para o topo.

  • Modo Emacs: Ctrl+Home

ScrollDisplayUp

Role a exibição para cima em uma tela.

  • Modo Windows: PageUp
  • Modo Emacs: PageUp

ScrollDisplayUpLine

Role a tela uma linha para cima.

  • Modo Windows: Ctrl+PageUp
  • Modo Emacs: Ctrl+PageUp

ShowCommandHelp

Fornece uma exibição da ajuda completa do cmdlet. Quando o cursor está no final de um parâmetro totalmente expandido, pressionando a <F1> tecla posiciona a exibição de ajuda no local desse parâmetro.

A ajuda é exibida em um buffer de tela alternativo usando um Pager do Microsoft.PowerShell.Pager. Ao sair do pager, você retornará à posição original do cursor na tela original. Este pager só funciona em aplicações de terminal modernas, como o Terminal Windows.

  • Modo Windows: F1
  • Modo Emacs: F1
  • Vi modo de inserção: F1
  • Modo de comando Vi: <F1>

ShowKeyBindings

Mostrar todas as chaves acopladas.

  • Modo Windows: Ctrl+Alt+?
  • Modo Emacs: Ctrl+Alt+?
  • Vi modo de inserção: Ctrl+Alt+?

ShowParameterHelp

Fornece ajuda dinâmica para parâmetros, mostrando-o abaixo da linha de comando atual como MenuComplete. O cursor deve estar no final do nome do parâmetro totalmente expandido quando você pressiona a <Alt+h> tecla .

  • Modo Windows: Alt+h
  • Modo Emacs: Alt+h
  • Vi modo de inserção: Alt+h
  • Modo de comando Vi: <Alt+h>

ViCommandMode

Mude o modo de operação atual de Vi-Insert para Vi-Command.

  • Vi modo de inserção: 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á vinculada.

ViEditVisualmente

Edite a linha de comando em um editor de texto especificado por $env:EDITOR ou $env:VISUAL.

  • Modo Emacs: Ctrl+x,Ctrl+e
  • Modo de comando Vi: <v>

ViExit [en]

Sai do shell.

  • A função não está vinculada.

ViInsertMode

Mude para o modo Inserir.

  • Modo de comando Vi: <i>

O que é fundamental

Leia uma chave e diga-me a que é que a chave está vinculada.

  • Modo Windows: Alt+?
  • Modo Emacs: Alt+?

Funções de previsão

AceitarPróximoSugestãoWord

Aceitar a próxima palavra da sugestão embutida ou selecionada

  • A função não está vinculada.

AceitarSugestão

Ao usar InlineView como estilo de exibição para previsão, aceite a sugestão embutida atual.

  • A função não está vinculada.

SeguinteSugestão

Ao usar ListView como estilo de exibição para previsão, navegue até a próxima sugestão na lista.

  • A função não está vinculada.

AnteriorSugestão

Ao usar ListView como estilo de exibição para previsão, navegue até a sugestão anterior na lista.

  • A função não está vinculada.

Dica de ferramenta ShowFullPrediction

Mostrar a dica de ferramenta do item de lista atualmente selecionado na exibição completa.

  • Modo Windows: F4
  • Modo Emacs: F4
  • Vi modo de inserção: F4

SwitchPredictionView

Alterne o estilo de exibição para previsão entre InlineView e ListView.

  • Modo Windows: F2
  • Modo Emacs: F2
  • Vi modo de inserção: F2

Funções de pesquisa

Pesquisa de Personagens

Leia um caractere e procure a próxima ocorrência desse personagem. Se um argumento for especificado, pesquise para frente (ou para trás, se negativo) para a enésima ocorrência.

  • Modo Windows: F3
  • Modo Emacs: Ctrl+]
  • Vi modo de inserção: F3
  • Modo de comando Vi: <F3>

CharacterSearchBackward

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 enésima ocorrência.

  • Modo Windows: Shift+F3
  • Modo Emacs: Ctrl+Alt+]
  • Vi modo de inserção: 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: <,>

Pesquisa repetida

Repita a última pesquisa na mesma direção que antes.

  • Modo de comando Vi: <n>

RepeatSearchBackward

Repita a última pesquisa na mesma direção que antes.

  • Modo de comando Vi: <N>

SearchChar

Leia o próximo personagem e encontre-o, daqui para frente.

  • Modo de comando Vi: <f>

SearchCharBackward

Leia o próximo personagem e encontre-o, retrocedendo.

  • Modo de comando Vi: <F>

SearchCharBackwardWithBackoff

Leia o próximo caractere e, em seguida, encontre-o, retrocedendo e, em seguida, recuando de um personagem.

  • Modo de comando Vi: <T>

SearchCharWithBackoff

Leia o próximo personagem e, em seguida, encontre-o, avançando e, em seguida, recue de um personagem.

  • Modo de comando Vi: <t>

PesquisarAvançar

Solicita uma cadeia de caracteres de pesquisa e inicia a pesquisa em AcceptLine.

  • Modo de comando Vi: <?>

Funções de seleção

ExchangePointAndMark

O cursor é colocado no local da marca e a marca é movida para o local do cursor.

  • Modo Emacs: Ctrl+x,Ctrl+x

SelecionarTodos

Selecione a linha inteira.

  • Modo Windows: Ctrl+a

SelectBackwardChar

Ajuste a seleção atual para incluir o caractere anterior.

  • Modo Windows: Shift+LeftArrow
  • Modo Emacs: Shift+LeftArrow

SelectBackwardsLine

Ajuste a seleção atual para incluir desde o cursor até o início da linha.

  • Modo Windows: Shift+Home
  • Modo Emacs: Shift+Home

SelecionarBackwardWord

Ajuste a seleção atual para incluir a palavra anterior.

  • Modo Windows: Shift+Ctrl+LeftArrow
  • Modo Emacs: Alt+B

SelectCommandArgument

Faça a seleção visual dos argumentos de comando. A seleção de argumentos tem como escopo um bloco de script. Com base na posição do cursor, ele pesquisa do bloco de script mais interno para o bloco de script mais externo e para quando encontra argumentos em um escopo de bloco de script.

Esta função honra DigitArgument. Ele trata os valores de argumento positivos ou negativos como os deslocamentos para frente ou para trás do argumento selecionado no momento ou da posição atual do cursor quando nenhum argumento é selecionado.

  • Modo Windows: Alt+a
  • Modo Emacs: Alt+a

SelectForwardChar

Ajuste a seleção atual para incluir o próximo caractere.

  • Modo Windows: Shift+RightArrow
  • Modo Emacs: Shift+RightArrow

SelectForwardWord

Ajuste a seleção atual para incluir a próxima palavra usando ForwardWord.

  • Modo Emacs: Alt+F

SelectLine

Ajuste a seleção atual para incluir do cursor até o final da linha.

  • Modo Windows: Shift+End
  • Modo Emacs: Shift+End

SelecionarSeguinteWord

Ajuste a seleção atual para incluir a próxima palavra.

  • Modo Windows: Shift+Ctrl+RightArrow

SelectShellBackwardWord

Ajuste a seleção atual para incluir a palavra anterior usando ShellBackwardWord.

  • A função não está vinculada.

SelectShellForwardWord

Ajuste a seleção atual para incluir a próxima palavra usando ShellForwardWord.

  • A função não está vinculada.

SelectShellNextWord

Ajuste a seleção atual para incluir a próxima palavra usando ShellNextWord.

  • A função não está vinculada.

Marca de conjunto

Marque o local atual do cursor para uso em um comando de edição subsequente.

  • Modo Emacs: Ctrl+@

APIs de suporte de vinculação de chave personalizada

As funções a seguir são públicas em Microsoft.PowerShell.PSConsoleReadLine, mas não podem ser vinculadas diretamente a uma chave. A maioria é útil em ligações de chave personalizadas.

void AddToHistory(string command)

Adicione uma linha de comando ao histórico sem executá-la.

void ClearKillRing()

Limpe o anel de morte. Isso é usado principalmente para testes.

void Delete(int start, int length)

Exclua caracteres de comprimento do início. Esta operação suporta desfazer/refazer.

void Ding()

Execute a ação Ding com base na preferência do usuário.

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 é usado se a sua ligação está fazendo algo mais avançado com o Ast.

IEnumerable[Microsoft.PowerShell.KeyHandler]
  GetKeyHandlers(bool includeBound, bool includeUnbound)

IEnumerable[Microsoft.PowerShell.KeyHandler]
  GetKeyHandlers(string[] Chord)

Estas duas funções são utilizadas pela Get-PSReadLineKeyHandler. O primeiro é usado para obter todas as ligações de chave. O segundo é usado para obter ligações de chave específicas.

Microsoft.PowerShell.PSConsoleReadLineOptions GetOptions()

Esta 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 nenhuma 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. Esta operação suporta desfazer/refazer.

string ReadLine(runspace remoteRunspace,
  System.Management.Automation.EngineIntrinsics engineIntrinsics)

Este é o principal ponto de entrada para o PSReadLine. Ele não suporta recursão, portanto, não é útil em uma vinculação de chave personalizada.

void RemoveKeyHandler(string[] key)

Esta 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 alguma entrada. Esta operação suporta desfazer/refazer. Isso é preferível a Excluir seguido de 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 é rastreado 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 honram DigitArgument. Uma chamada típica tem a seguinte aparência:

[int]$numericArg = 0
[Microsoft.PowerShell.PSConsoleReadLine]::TryGetArgAsInt($arg,
  [ref]$numericArg, 1)

Notas

Comportamento do evento OnIdle

  • Quando PSReadLine está em uso, o evento OnIdle é acionado quando ReadKey() o tempo limite expira (sem digitar em 300ms). O evento pode ser sinalizado enquanto o usuário está no meio da edição de uma linha de comando, por exemplo, o usuário está lendo ajuda para decidir qual parâmetro usar.

    A partir do PSReadLine 2.2.0-beta4, o comportamento do OnIdle foi alterado para sinalizar o evento somente se houver um ReadKey() tempo limite e o buffer de edição atual estiver vazio.

Consulte Também