Copy-Item
Copia um item de um local para outro.
Sintaxe
Copy-Item
[-Path] <String[]>
[[-Destination] <String>]
[-Container]
[-Force]
[-Filter <String>]
[-Include <String[]>]
[-Exclude <String[]>]
[-Recurse]
[-PassThru]
[-Credential <PSCredential>]
[-WhatIf]
[-Confirm]
[-FromSession <PSSession>]
[-ToSession <PSSession>]
[<CommonParameters>]
Copy-Item
-LiteralPath <String[]>
[[-Destination] <String>]
[-Container]
[-Force]
[-Filter <String>]
[-Include <String[]>]
[-Exclude <String[]>]
[-Recurse]
[-PassThru]
[-Credential <PSCredential>]
[-WhatIf]
[-Confirm]
[-FromSession <PSSession>]
[-ToSession <PSSession>]
[<CommonParameters>]
Copy-Item
[-Path] <string[]>
[[-Destination] <string>]
[-Container]
[-Force]
[-Filter <string>]
[-Include <string[]>]
[-Exclude <string[]>]
[-Recurse]
[-PassThru]
[-Credential <pscredential>]
[-WhatIf]
[-Confirm]
[<CommonParameters>]
Copy-Item
[[-Destination] <string>]
-LiteralPath <string[]>
[-Container]
[-Force]
[-Filter <string>]
[-Include <string[]>]
[-Exclude <string[]>]
[-Recurse]
[-PassThru]
[-Credential <pscredential>]
[-WhatIf]
[-Confirm]
[<CommonParameters>]
Description
O cmdlet Copy-Item
copia um item de um local para outro no mesmo namespace.
Por exemplo, ele pode copiar um arquivo para uma pasta, mas não pode copiar um arquivo para uma unidade de certificado.
Este cmdlet não corta nem exclui os itens que estão sendo copiados. Os itens específicos que o cmdlet pode copiar dependem do provedor do PowerShell que expõe o item. Por exemplo, ele pode copiar arquivos e diretórios em uma unidade do sistema de arquivos e chaves de registro e entradas na unidade de registro.
Este cmdlet pode copiar e renomear itens no mesmo comando. Para renomear um item, insira o novo nome no valor do parâmetro Destination. Para renomear um item e não copiá-lo, use o cmdlet Rename-Item
.
Exemplos
Exemplo 1: Copiar um arquivo para o diretório especificado
Este exemplo copia o arquivo mar1604.log.txt
para o diretório C:\Presentation
. O ficheiro original não é eliminado.
Copy-Item "C:\Wabash\Logfiles\mar1604.log.txt" -Destination "C:\Presentation"
Exemplo 2: Copiar o conteúdo do diretório para um diretório existente
Este exemplo copia o conteúdo do diretório C:\Logfiles
para o diretório C:\Drawings
existente. O diretório Logfiles
não é copiado.
Se o diretório Logfiles
tiver arquivos em subdiretórios, esses subdiretórios serão copiados com suas árvores de arquivos intactas. Por padrão, o parâmetro Container é definido como True, que preserva a estrutura de diretórios.
Copy-Item -Path "C:\Logfiles\*" -Destination "C:\Drawings" -Recurse
Observação
Se o caminho C:\Drawings
não existir, o cmdlet copiará todos os arquivos da pasta Logfiles
em um único arquivo C:\Drawings
.
Exemplo 3: Copiar diretório e conteúdo para um novo diretório
Este exemplo copia o conteúdo do diretório de origem C:\Logfiles
e cria um novo diretório de destino. O novo diretório de destino, \Logs
é criado em C:\Drawings
.
Para incluir o nome do diretório de origem, copie para um diretório de destino existente, conforme mostrado no Exemplo 2. Ou, nomeie o novo diretório de destino com o mesmo que o diretório de origem.
Copy-Item -Path "C:\Logfiles" -Destination "C:\Drawings\Logs" -Recurse
Observação
Se o Caminho do
Copy-Item -Path "C:\Logfiles\*" -Destination "C:\Drawings\Logs" -Recurse
Exemplo 4: Copiar um arquivo para o diretório especificado e renomear o arquivo
Este exemplo usa o cmdlet Copy-Item
para copiar o script Get-Widget.ps1
do diretório \\Server01\Share
para o diretório \\Server12\ScriptArchive
. Como parte da operação de cópia, o comando altera o nome do item de Get-Widget.ps1
para Get-Widget.ps1.txt
, para que possa ser anexado com segurança às mensagens de e-mail.
Copy-Item "\\Server01\Share\Get-Widget.ps1" -Destination "\\Server12\ScriptArchive\Get-Widget.ps1.txt"
Exemplo 5: Copiar um ficheiro para um computador remoto
Uma sessão é criada no computador remoto chamado Server01 com a credencial de Contoso\User01
e armazena os resultados na variável chamada $Session
.
O cmdlet Copy-Item
copia test.log
da pasta D:\Folder001
para a pasta C:\Folder001_Copy
no computador remoto usando as informações de sessão armazenadas na variável $Session
. O ficheiro original não é eliminado.
$Session = New-PSSession -ComputerName "Server01" -Credential "Contoso\User01"
Copy-Item "D:\Folder001\test.log" -Destination "C:\Folder001_Copy\" -ToSession $Session
Exemplo 6: Copiar uma pasta para um computador remoto
Uma sessão é criada no computador remoto chamado Server01 com a credencial de Contoso\User01
e armazena os resultados na variável chamada $Session
.
O cmdlet Copy-Item
copia a pasta D:\Folder002
para o diretório C:\Folder002_Copy
no computador remoto usando as informações de sessão armazenadas na variável $Session
. As subpastas ou arquivos não são copiados sem usar a opção Folder002_Copy
se ela ainda não existir.
$Session = New-PSSession -ComputerName "Server02" -Credential "Contoso\User01"
Copy-Item "D:\Folder002\" -Destination "C:\Folder002_Copy\" -ToSession $Session
Exemplo 7: Copiar recursivamente todo o conteúdo de uma pasta para um computador remoto
Uma sessão é criada no computador remoto chamado Server01 com a credencial de Contoso\User01
e armazena os resultados na variável chamada $Session
.
O cmdlet Copy-Item
copia todo o conteúdo da pasta D:\Folder003
para o diretório C:\Folder003_Copy
no computador remoto usando as informações de sessão armazenadas na variável $Session
. As subpastas são copiadas com suas árvores de arquivos intactas. A operação cria a pasta Folder003_Copy
se ela ainda não existir.
$Session = New-PSSession -ComputerName "Server04" -Credential "Contoso\User01"
Copy-Item "D:\Folder003\" -Destination "C:\Folder003_Copy\" -ToSession $Session -Recurse
Exemplo 8: Copiar um ficheiro para um computador remoto e, em seguida, mudar o nome do ficheiro
Uma sessão é criada no computador remoto chamado Server01 com a credencial de Contoso\User01
e armazena os resultados na variável chamada $Session
.
O cmdlet Copy-Item
copia scriptingexample.ps1
da pasta D:\Folder004
para a pasta C:\Folder004_Copy
no computador remoto usando as informações de sessão armazenadas na variável $Session
. O ficheiro original não é eliminado.
$Session = New-PSSession -ComputerName "Server04" -Credential "Contoso\User01"
Copy-Item "D:\Folder004\scriptingexample.ps1" -Destination "C:\Folder004_Copy\scriptingexample_copy.ps1" -ToSession $Session
Exemplo 9: Copiar um ficheiro remoto para o computador local
Uma sessão é criada no computador remoto chamado Server01 com a credencial de Contoso\User01
e armazena os resultados na variável chamada $Session
.
O cmdlet Copy-Item
copia test.log
do C:\MyRemoteData\
remoto para a pasta D:\MyLocalData
local usando as informações de sessão armazenadas na variável $Session
. O ficheiro original não é eliminado.
$Session = New-PSSession -ComputerName "Server01" -Credential "Contoso\User01"
Copy-Item "C:\MyRemoteData\test.log" -Destination "D:\MyLocalData\" -FromSession $Session
Exemplo 10: Copiar todo o conteúdo de uma pasta remota para o computador local
Uma sessão é criada no computador remoto chamado Server01 com a credencial de Contoso\User01
e armazena os resultados na variável chamada $Session
.
O cmdlet Copy-Item
copia todo o conteúdo da pasta C:\MyRemoteData\scripts
remota para a pasta D:\MyLocalData
local usando as informações de sessão armazenadas na variável $Session
. Se a pasta scripts tiver arquivos em subpastas, essas subpastas serão copiadas com suas árvores de arquivos intactas.
$Session = New-PSSession -ComputerName "Server01" -Credential "Contoso\User01"
Copy-Item "C:\MyRemoteData\scripts" -Destination "D:\MyLocalData\" -FromSession $Session
Exemplo 11: Copie recursivamente todo o conteúdo de uma pasta remota para o computador local
Uma sessão é criada no computador remoto chamado Server01 com a credencial de Contoso\User01
e armazena os resultados na variável chamada $Session
.
O cmdlet Copy-Item
copia todo o conteúdo da pasta C:\MyRemoteData\scripts
remota para a pasta D:\MyLocalData\scripts
local usando as informações de sessão armazenadas na variável $Session
. Como o parâmetro Recurse é usado, a operação cria a pasta de scripts se ela ainda não existir. Se a pasta scripts tiver arquivos em subpastas, essas subpastas serão copiadas com suas árvores de arquivos intactas.
$Session = New-PSSession -ComputerName "Server01" -Credential "Contoso\User01"
Copy-Item "C:\MyRemoteData\scripts" -Destination "D:\MyLocalData\scripts" -FromSession $Session -Recurse
Exemplo 12: Copiar recursivamente arquivos de uma árvore de pastas para a pasta atual
Este exemplo mostra como copiar arquivos de uma estrutura de pastas de vários níveis para uma única pasta plana.
Os três primeiros comandos mostram a estrutura de pastas existente e o conteúdo de dois arquivos, ambos os nomes file3.txt
.
PS C:\temp\test> (Get-ChildItem C:\temp\tree -Recurse).FullName
C:\temp\tree\subfolder
C:\temp\tree\file1.txt
C:\temp\tree\file2.txt
C:\temp\tree\file3.txt
C:\temp\tree\subfolder\file3.txt
C:\temp\tree\subfolder\file4.txt
C:\temp\tree\subfolder\file5.txt
PS C:\temp\test> Get-Content C:\temp\tree\file3.txt
This is file3.txt in the root folder
PS C:\temp\test> Get-Content C:\temp\tree\subfolder\file3.txt
This is file3.txt in the subfolder
PS C:\temp\test> Copy-Item -Path C:\temp\tree -Filter *.txt -Recurse -Container:$false
PS C:\temp\test> (Get-ChildItem . -Recurse).FullName
C:\temp\test\subfolder
C:\temp\test\file1.txt
C:\temp\test\file2.txt
C:\temp\test\file3.txt
C:\temp\test\file4.txt
C:\temp\test\file5.txt
PS C:\temp\test> Get-Content .\file3.txt
This is file3.txt in the subfolder
O cmdlet Copy-Item
tem o parâmetro Container definido como $false
. Isso faz com que o conteúdo da pasta de origem seja copiado, mas não preserva a estrutura da pasta. Observe que os arquivos com o mesmo nome são substituídos na pasta de destino.
Exemplo 13: Usando filtros para copiar itens sem recursão
Este exemplo mostra os resultados usando o parâmetro Include para selecionar os itens a serem copiados.
Este exemplo usa a seguinte estrutura de pastas que contém os arquivos a serem copiados:
D:\temp\tree\example.ps1
D:\temp\tree\example.txt
D:\temp\tree\examples\
D:\temp\tree\examples\example_1.txt
D:\temp\tree\examples\example_2.txt
D:\temp\tree\examples\subfolder\
D:\temp\tree\examples\subfolder\test.txt
Neste exemplo, Copy-Item
é chamado com um curinga para os parâmetros Path e Include. A especificação de um curinga para o parâmetro Path garante que ele processe todos os arquivos e pastas que correspondam D:\temp\tree\*
. O parâmetro Include filtra a lista de itens a serem processados, limitando a operação apenas aos caminhos que começam com ex
.
PS D:\temp\test\out> Copy-Item -Path D:\temp\tree\* -Include ex*
PS D:\temp\test\out> (Get-ChildItem -Recurse).FullName
D:\temp\out\examples
D:\temp\out\example.ps1
D:\temp\out\example.txt
O parâmetro Include é aplicado ao conteúdo de D:\temp\tree
pasta para copiar todos os itens que correspondem ex*
. Observe que, sem recursão, a pasta D:\temp\out\examples
é copiada, mas nenhum de seu conteúdo é copiado.
Exemplo 14: Usando filtros para copiar itens com recursão
Este exemplo mostra os resultados usando o parâmetro Include para selecionar os itens a serem copiados.
Este exemplo usa a seguinte estrutura de pastas que contém os arquivos a serem copiados:
D:\temp\tree\example.ps1
D:\temp\tree\example.txt
D:\temp\tree\examples\
D:\temp\tree\examples\example_1.txt
D:\temp\tree\examples\example_2.txt
D:\temp\tree\examples\subfolder\
D:\temp\tree\examples\subfolder\test.txt
Neste exemplo, Copy-Item
é chamado com um curinga para os parâmetros Path e Include. Especificar um curinga para o parâmetro Path garante que ele processe todos os arquivos e pastas que correspondem D:\temp\tree\*
. O parâmetro Include filtra a lista de itens a serem processados, limitando a operação apenas aos caminhos que começam com ex
.
D:\temp\out> Copy-Item -Path D:\temp\tree\* -Include ex* -Recurse
D:\temp\out> (Get-ChildItem -Recurse).FullName
D:\temp\out\examples
D:\temp\out\example.ps1
D:\temp\out\example.txt
D:\temp\out\examples\subfolder
D:\temp\out\examples\example_1.txt
D:\temp\out\examples\example_2.txt
D:\temp\out\examples\subfolder\test.txt
O parâmetro Include é aplicado ao conteúdo de D:\temp\tree
pasta para copiar todos os itens que correspondem ex*
. Observe que, com a recursão, a pasta D:\temp\out\examples
é copiada junto com todos os arquivos e subpastas. A cópia inclui arquivos que não correspondem ao filtro de inclusão. Ao usar Copy-Item
, os filtros só se aplicam ao nível superior especificado pelo parâmetro Path. Em seguida, a recursão é aplicada a esses itens correspondentes.
Observação
O comportamento do parâmetro Exclude é o mesmo descrito neste exemplo, exceto que ele limita a operação apenas aos caminhos que não correspondem ao padrão.
Exemplo 15: Limitar os arquivos para copiar recursivamente de um caminho especificado por curinga
Este exemplo mostra como limitar os arquivos copiados recursivamente de um caminho de correspondência curinga para outra pasta. O Exemplo 13 mostra que, como o parâmetro Get-ChildItem
para localizar os itens que deseja copiar e passar esses itens para Copy-Item
.
Este exemplo usa a seguinte estrutura de pastas que contém os arquivos a serem copiados:
D:\temp\tree\example.ps1
D:\temp\tree\example.txt
D:\temp\tree\examples\
D:\temp\tree\examples\example_1.txt
D:\temp\tree\examples\example_2.txt
D:\temp\tree\examples\subfolder\
D:\temp\tree\examples\subfolder\test.txt
Para copiar todos os itens que começam com ex*
, use Get-ChildItem
com os parâmetros Recurse e Filter e canalize os resultados para Copy-Item
.
D:\temp\out> Get-ChildItem -Path D:\temp\tree -Recurse -Filter ex* | Copy-Item
D:\temp\out> (Get-ChildItem -Recurse).FullName
D:\temp\out\examples
D:\temp\out\example_1.txt
D:\temp\out\example_2.txt
D:\temp\out\example.ps1
D:\temp\out\example.txt
Ao contrário do Copy-Item
, o parâmetro Filter para Get-ChildItem
aplica-se aos itens descobertos durante a recursão. Isso permite que você localize, filtre e copie itens recursivamente.
Parâmetros
-Confirm
Solicita confirmação antes de executar o cmdlet.
Tipo: | SwitchParameter |
Aliases: | cf |
Position: | Named |
Default value: | False |
Necessário: | False |
Aceitar entrada de pipeline: | False |
Aceitar carateres universais: | False |
-Container
Indica que esse cmdlet preserva objetos de contêiner durante a operação de cópia. Por padrão, o parâmetro Container é definido como True.
Tipo: | SwitchParameter |
Position: | Named |
Default value: | True |
Necessário: | False |
Aceitar entrada de pipeline: | False |
Aceitar carateres universais: | False |
-Credential
Observação
Esse parâmetro não é suportado por nenhum provedor instalado com o PowerShell. Para representar outro usuário ou elevar suas credenciais ao executar esse cmdlet, use Invoke-Command.
Tipo: | PSCredential |
Position: | Named |
Default value: | Current user |
Necessário: | False |
Aceitar entrada de pipeline: | True |
Aceitar carateres universais: | False |
-Destination
Especifica o caminho para o novo local. O padrão é o diretório atual.
Para renomear o item que está sendo copiado, especifique um novo nome no valor do parâmetro Destination.
Tipo: | String |
Position: | 1 |
Default value: | Current directory |
Necessário: | False |
Aceitar entrada de pipeline: | True |
Aceitar carateres universais: | False |
-Exclude
Especifica um ou mais elementos ou padrões de caminho, como "*.txt"
, para limitar a operação desse cmdlet. O valor desse parâmetro filtra em relação ao resultado de correspondência curinga do parâmetro Path
Tipo: | String[] |
Position: | Named |
Default value: | None |
Necessário: | False |
Aceitar entrada de pipeline: | False |
Aceitar carateres universais: | True |
-Filter
Especifica um filtro para qualificar o parâmetro Path
Tipo: | String |
Position: | Named |
Default value: | None |
Necessário: | False |
Aceitar entrada de pipeline: | False |
Aceitar carateres universais: | True |
-Force
Indica que esse cmdlet copia itens que não podem ser alterados de outra forma, como copiar sobre um arquivo somente leitura ou alias.
Tipo: | SwitchParameter |
Position: | Named |
Default value: | False |
Necessário: | False |
Aceitar entrada de pipeline: | False |
Aceitar carateres universais: | False |
-FromSession
Este é um parâmetro dinâmico disponibilizado pelo provedor FileSystem.
Especifique o objeto PSSession do qual um arquivo remoto está sendo copiado. Quando você usa esse parâmetro, os parâmetros Path e LiteralPath referem-se ao caminho local na máquina remota.
Para obter mais informações, consulte about_FileSystem_Provider.
Tipo: | PSSession |
Position: | Named |
Default value: | None |
Necessário: | False |
Aceitar entrada de pipeline: | False |
Aceitar carateres universais: | False |
-Include
Especifica um ou mais elementos ou padrões de caminho, como "*.txt"
, para limitar a operação desse cmdlet. O valor desse parâmetro filtra em relação ao resultado de correspondência curinga do parâmetro Path
Tipo: | String[] |
Position: | Named |
Default value: | None |
Necessário: | False |
Aceitar entrada de pipeline: | False |
Aceitar carateres universais: | True |
-LiteralPath
Especifica um caminho para um ou mais locais. O valor de LiteralPath é usado exatamente como é digitado. Nenhum caractere é interpretado como curinga. Se o caminho incluir caracteres de escape, coloque-o entre aspas simples. Aspas simples dizem ao PowerShell para não interpretar nenhum caractere como sequências de escape.
Para obter mais informações, consulte about_Quoting_Rules.
Tipo: | String[] |
Aliases: | PSPath, LP |
Position: | Named |
Default value: | None |
Necessário: | True |
Aceitar entrada de pipeline: | True |
Aceitar carateres universais: | False |
-PassThru
Retorna um objeto que representa o item com o qual você está trabalhando. Por padrão, esse cmdlet não gera nenhuma saída.
Tipo: | SwitchParameter |
Position: | Named |
Default value: | False |
Necessário: | False |
Aceitar entrada de pipeline: | False |
Aceitar carateres universais: | False |
-Path
Especifica, como uma matriz de cadeia de caracteres, o caminho para os itens a serem copiados. Caracteres curinga são permitidos.
Tipo: | String[] |
Position: | 0 |
Default value: | None |
Necessário: | True |
Aceitar entrada de pipeline: | True |
Aceitar carateres universais: | True |
-Recurse
Indica que esse cmdlet faz uma cópia recursiva.
Tipo: | SwitchParameter |
Position: | Named |
Default value: | False |
Necessário: | False |
Aceitar entrada de pipeline: | False |
Aceitar carateres universais: | False |
-ToSession
Este é um parâmetro dinâmico disponibilizado pelo provedor FileSystem.
Especifique o objeto PSSession para o qual um arquivo remoto está sendo copiado. Quando você usa esse parâmetro, o parâmetro Destination refere-se ao caminho local na máquina remota.
Para obter mais informações, consulte about_FileSystem_Provider.
Tipo: | PSSession |
Position: | Named |
Default value: | None |
Necessário: | False |
Aceitar entrada de pipeline: | False |
Aceitar carateres universais: | False |
-WhatIf
Mostra o que aconteceria se o cmdlet fosse executado. O cmdlet não é executado.
Tipo: | SwitchParameter |
Aliases: | wi |
Position: | Named |
Default value: | False |
Necessário: | False |
Aceitar entrada de pipeline: | False |
Aceitar carateres universais: | False |
Entradas
Você pode canalizar uma cadeia de caracteres que contenha um caminho para esse cmdlet.
Saídas
None
Por padrão, esse cmdlet não retorna nenhuma saída.
Quando você usa o parâmetro PassThru, esse cmdlet retorna um objeto que representa o item copiado.
Notas
O PowerShell inclui os seguintes aliases para Copy-Item
:
- Todas as plataformas:
copy
cpi
- Janelas:
cp
Este cmdlet foi projetado para trabalhar com os dados expostos por qualquer provedor. Para listar os provedores disponíveis em sua sessão, digite Get-PSProvider
. Para obter mais informações, consulte about_Providers.