Add-History
Acrescenta entradas ao histórico da sessão.
Sintaxe
Add-History
[[-InputObject] <PSObject[]>]
[-Passthru]
[<CommonParameters>]
Description
O cmdlet Add-History
adiciona entradas ao final do histórico da sessão, ou seja, à lista de comandos inseridos durante a sessão atual.
Você pode usar o cmdlet Get-History
para obter os comandos e passá-los para Add-History
, ou pode exportar os comandos para um arquivo CSV ou XML, importar os comandos e passar o arquivo importado para Add-History
.
Você pode usar esse cmdlet para adicionar comandos específicos ao histórico ou para criar um único arquivo de histórico que inclua comandos de mais de uma sessão.
Exemplos
Exemplo 1: Adicionar comandos ao histórico de uma sessão diferente
# Get objects representing the commands in the history and exports them to the History.csv file.
Get-History | Export-Csv c:\testing\history.csv
# Use the `Import-Csv` cmdlet to import the objects in the History.csv file.
Import-Csv history.csv | Add-History
Esses comandos adicionam os comandos digitados em uma sessão do Windows PowerShell ao histórico de uma sessão diferente do Windows PowerShell. O segundo comando é digitado na linha de comando de uma sessão diferente.
O operador de pipeline |
passa os objetos para o cmdlet Add-History
, que adiciona os objetos que representam os comandos no arquivo History.csv ao histórico de sessões atual.
Exemplo 2: Importar e executar comandos
Import-Clixml c:\temp\history.xml | Add-History -Passthru | ForEach-Object -Process {Invoke-History}
Este comando importa comandos do arquivo History.xml, adiciona-os ao histórico da sessão atual e executa os comandos no histórico combinado.
O cmdlet Import-Clixml
importa um histórico de comandos que foi exportado para o arquivo History.xml.
O operador de pipeline passa os comandos para o cmdlet Add-History
, que adiciona os comandos ao histórico da sessão atual.
O parâmetro PassThru passa os objetos que representam os comandos adicionados pelo pipeline.
O cmdlet ForEach-Object
aplicar o comando Invoke-History
a cada um dos comandos no histórico combinado.
O comando Invoke-History
é formatado como um bloco de script, entre chaves, conforme exigido pelo parâmetro Process do cmdlet ForEach-Object
.
Exemplo 3: Adicionar comandos no histórico ao final do histórico
Get-History -Id 5 -Count 5 | Add-History
Este comando adiciona os cinco primeiros comandos do histórico ao final da lista de histórico.
Ele usa o cmdlet Get-History
para obter os cinco comandos que terminam no comando 5.
O operador de pipeline os passa para o cmdlet Add-History
, que os acrescenta ao histórico atual.
O comando Add-History
não inclui parâmetros, mas o Windows PowerShell associa os objetos passados pelo pipeline ao parâmetro InputObject de Add-History
.
Exemplo 4: Adicionar comandos em um arquivo .csv ao histórico atual
$a = Import-Csv c:\testing\history.csv
Add-History -InputObject $a -PassThru
Esses comandos adicionam os comandos no arquivo History.csv ao histórico de sessões atual.
O primeiro comando usa o cmdlet Import-Csv
para importar os comandos no arquivo History.csv e armazenar seu conteúdo na variável $a
.
O segundo comando usa o cmdlet Add-History
para adicionar os comandos do History.csv ao histórico da sessão atual.
Ele usa o parâmetro InputObject para especificar a variável $a e o parâmetro PassThru para gerar um objeto a ser exibido na linha de comando.
Sem o parâmetro PassThru, o cmdlet Add-History
não gera nenhuma saída.
Exemplo 5: Adicionar comandos em um arquivo .xml ao histórico atual
Add-History -InputObject (Import-Clixml c:\temp\history01.xml)
Este comando adiciona os comandos no arquivo History01.xml ao histórico da sessão atual.
Ele usa o parâmetro InputObject para passar os resultados do comando entre parênteses para o cmdlet Add-History
.
O comando entre parênteses, que é executado primeiro, importa o arquivo History01.xml para o Windows PowerShell. Em seguida, o cmdlet Add-History
adiciona os comandos no arquivo ao histórico da sessão.
Parâmetros
-InputObject
Especifica uma matriz de entradas a serem adicionadas ao histórico como objeto HistoryInfo ao histórico da sessão.
Você pode usar esse parâmetro para enviar um objeto HistoryInfo
Tipo: | PSObject[] |
Position: | 0 |
Default value: | None |
Necessário: | False |
Aceitar entrada de pipeline: | True |
Aceitar carateres universais: | False |
-Passthru
Indica que esse cmdlet retorna um objeto de histórico para cada entrada de histórico. Por padrão, esse cmdlet não gera nenhuma saída.
Tipo: | SwitchParameter |
Position: | Named |
Default value: | None |
Necessário: | False |
Aceitar entrada de pipeline: | False |
Aceitar carateres universais: | False |
Entradas
Você pode canalizar um objeto HistoryInfo para esse cmdlet.
Saídas
None or Microsoft.PowerShell.Commands.HistoryInfo
Este cmdlet retorna um objeto HistoryInfo
Notas
O histórico da sessão é uma lista dos comandos inseridos durante a sessão, juntamente com o ID. O histórico da sessão representa a ordem de execução, o status e as horas de início e término do comando. À medida que você insere cada comando, o Windows PowerShell o adiciona ao histórico para que você possa reutilizá-lo. Para obter mais informações sobre o histórico da sessão, consulte about_History.
Para especificar os comandos a serem adicionados ao histórico, use o parâmetro InputObject. O comando
Add-History
aceita apenas objetos HistoryInfo, como os retornados para cada comando pelo cmdletGet-History
. Não é possível passar um caminho e nome de arquivo ou uma lista de comandos.Você pode usar o parâmetro InputObject para passar um arquivo de objetos HistoryInfo para
Add-History
. Para fazer isso, exporte os resultados de um comandoGet-History
para um arquivo usando o cmdletExport-Csv
ouExport-Clixml
e, em seguida, importe o arquivo usando os cmdletsImport-Csv
ouImport-Clixml
. Em seguida, você pode passar o arquivo de objetos HistoryInfoimportados para através de um pipeline ou em uma variável. Para obter mais informações, consulte os exemplos. O arquivo de
objetos HistoryInfo que você passa para o cmdletdeve incluir as informações de tipo, cabeçalhos de coluna e todas as propriedades dos objetos HistoryInfo. Se você pretende passar os objetos de volta para Add-History
, não use o parâmetro NoTypeInformation do cmdletExport-Csv
e não exclua as informações de tipo, cabeçalhos de coluna ou quaisquer campos no arquivo. Para modificar o histórico da sessão, exporte a sessão para um arquivo CSV ou XML, modifique o arquivo, importe o arquivo e useAdd-History
para anexá-lo ao histórico da sessão atual.