Select-Xml
Localiza texto em uma cadeia de caracteres XML ou documento.
Sintaxe
Select-Xml
[-XPath] <string>
[-Xml] <XmlNode[]>
[-Namespace <hashtable>]
[<CommonParameters>]
Select-Xml
[-XPath] <string>
[-Path] <string[]>
[-Namespace <hashtable>]
[<CommonParameters>]
Select-Xml
[-XPath] <string>
-LiteralPath <string[]>
[-Namespace <hashtable>]
[<CommonParameters>]
Select-Xml
[-XPath] <string>
-Content <string[]>
[-Namespace <hashtable>]
[<CommonParameters>]
Description
O cmdlet Select-Xml
permite usar consultas XPath para pesquisar texto em cadeias de caracteres XML e documentos.
Insira uma consulta XPath e use o Content, Pathou parâmetro Xml para especificar o XML a ser pesquisado.
Exemplos
Exemplo 1: Selecionar nós AliasProperty
Este exemplo obtém as propriedades de alias no Types.ps1xml
. Para obter informações sobre esse arquivo, consulte about_Types.ps1xml.
O primeiro comando salva o caminho para o arquivo Types.ps1xml
na variável $Path
.
O segundo comando salva o caminho XML no nó AliasProperty na variável $XPath
.
O cmdlet Select-Xml
obtém os nós AliasProperty identificados pela instrução XPath do arquivo Types.ps1xml
. O comando usa um operador de pipeline (|
) para enviar os nós de AliasProperty para o cmdlet Select-Object
. O parâmetro ExpandProperty expande o objeto Node e retorna suas propriedades Name e ReferencedMemberName.
$Path = "$Pshome\Types.ps1xml"
$XPath = "/Types/Type/Members/AliasProperty"
Select-Xml -Path $Path -XPath $Xpath | Select-Object -ExpandProperty Node
Name ReferencedMemberName
---- --------------------
Count Length
Name Key
Name ServiceName
RequiredServices ServicesDependedOn
ProcessName Name
Handles Handlecount
VM VirtualSize
WS WorkingSetSize
Name ProcessName
Handles Handlecount
VM VirtualMemorySize
WS WorkingSet
PM PagedMemorySize
NPM NonpagedSystemMemorySize
Name __Class
Namespace ModuleName
O resultado mostra o Name e ReferencedMemberName de cada propriedade alias no arquivo Types.ps1xml
. Por exemplo, há uma propriedade Count que é um alias da propriedade Length.
Exemplo 2: Inserir um documento XML
Este exemplo mostra como usar o parâmetro XML para fornecer um documento XML ao cmdlet Select-Xml
.
O cmdlet Get-Content
obtém o conteúdo do arquivo Types.ps1xml
e o salva na variável $Types
. O [xml]
converte a variável como um objeto XML.
O cmdlet Select-Xml
obtém os nós MethodName no arquivo Types.ps1xml
. O comando usa o parâmetro Xml para especificar o conteúdo XML na variável $Types
e o parâmetro XPath para especificar o caminho para o nó MethodName.
[xml]$Types = Get-Content $Pshome\Types.ps1xml
Select-Xml -Xml $Types -XPath "//MethodName"
Exemplo 3: Pesquisar arquivos de Ajuda do PowerShell
Este exemplo mostra como usar o cmdlet Select-Xml
para pesquisar os arquivos de ajuda do cmdlet baseado em XML do PowerShell. Neste exemplo, procuraremos o nome do cmdlet que serve de título para cada arquivo de ajuda e o caminho para o arquivo de ajuda.
A variável $Namespace
contém uma tabela de hash que representa o namespace XML usado para os arquivos de ajuda.
A variável $Path
contém o caminho para os arquivos de ajuda do PowerShell. Se não houver arquivos de ajuda nesse caminho no computador, use o cmdlet Update-Help
para baixar os arquivos de ajuda. Para obter mais informações sobre a Ajuda atualizável, consulte about_Updatable_Help.
O cmdlet Select-Xml
pesquisa nomes de cmdlets nos arquivos XML localizando Command:Name
elemento em qualquer lugar dos arquivos. Os resultados são armazenados na variável $Xml
.
Select-Xml
retorna um objeto SelectXmlInfo que tem uma propriedade Node, que é um objeto System.Xml.XmlElement.
A propriedade Node tem uma propriedade InnerXML que contém o XML real que é recuperado.
A variável $Xml
é canalizada para o cmdlet Format-Table
. O comando Format-Table
usa uma propriedade calculada para obter a propriedade Node.InnerXML de cada objeto na variável $Xml
, cortar o espaço em branco antes e depois do texto e exibi-lo na tabela, juntamente com o Caminho para o arquivo de origem.
$Namespace = @{
command = "http://schemas.microsoft.com/maml/dev/command/2004/10"
maml = "http://schemas.microsoft.com/maml/2004/10"
dev = "http://schemas.microsoft.com/maml/dev/2004/10"
}
$Path = "$Pshome\en-us\*dll-Help.xml"
$Xml = Select-Xml -Path $Path -Namespace $Namespace -XPath "//command:name"
$Xml | Format-Table @{Label="Name"; Expression= {($_.Node.InnerXml).trim()}}, Path -AutoSize
Name Path
---- ----
Export-Counter C:\Windows\system32\WindowsPowerShell\v1.0\en-us\Microsoft.PowerShell.Commands.Diagnostics.dll-Help.xml
Get-Counter C:\Windows\system32\WindowsPowerShell\v1.0\en-us\Microsoft.PowerShell.Commands.Diagnostics.dll-Help.xml
Get-WinEvent C:\Windows\system32\WindowsPowerShell\v1.0\en-us\Microsoft.PowerShell.Commands.Diagnostics.dll-Help.xml
Import-Counter C:\Windows\system32\WindowsPowerShell\v1.0\en-us\Microsoft.PowerShell.Commands.Diagnostics.dll-Help.xml
Add-Computer C:\Windows\system32\WindowsPowerShell\v1.0\en-us\Microsoft.PowerShell.Commands.Management.dll-Help.xml
Add-Content C:\Windows\system32\WindowsPowerShell\v1.0\en-us\Microsoft.PowerShell.Commands.Management.dll-Help.xml
Checkpoint-Computer C:\Windows\system32\WindowsPowerShell\v1.0\en-us\Microsoft.PowerShell.Commands.Management.dll-Help.xml
...
Exemplo 4: Diferentes maneiras de inserir XML
Este exemplo mostra duas maneiras diferentes de enviar XML para o cmdlet Select-Xml
.
O primeiro comando salva uma cadeia de caracteres here, que contém XML na variável $Xml
. Para obter mais informações sobre here-strings, consulte about_Quoting_Rules.
Select-Xml
usa o parâmetro Content para especificar o XML na variável $Xml
.
O terceiro comando é o mesmo que o segundo, exceto que tt usa um operador de pipeline (|
) para enviar o XML na variável $Xml
para o cmdlet Select-Xml
.
$Xml = @"
<?xml version="1.0" encoding="utf-8"?>
<Book>
<projects>
<project name="Book1" date="2009-01-20">
<editions>
<edition language="English">En.Book1.com</edition>
<edition language="German">Ge.Book1.Com</edition>
<edition language="French">Fr.Book1.com</edition>
<edition language="Polish">Pl.Book1.com</edition>
</editions>
</project>
</projects>
</Book>
"@
Select-Xml -Content $Xml -XPath "//edition" | foreach {$_.node.InnerXML}
En.Book1.com
Ge.Book1.Com
Fr.Book1.com
Pl.Book1.com
$Xml | Select-Xml -XPath "//edition" | foreach {$_.node.InnerXML}
En.Book1.com
Ge.Book1.Com
Fr.Book1.com
Pl.Book1.com
Exemplo 5: Usar o namespace xmlns padrão
Este exemplo mostra como usar o cmdlet Select-Xml
com documentos XML que usam o namespace xmlns padrão. O exemplo obtém os títulos dos arquivos de snippet criados pelo usuário do Windows PowerShell ISE. Para obter informações sobre trechos, consulte New-IseSnippet.
A variável $SnippetNamespace
contém uma tabela de hash para o namespace padrão que os arquivos XML de trechos usam. O valor da tabela de hash é o URI do esquema XMLNS no XML do trecho. O nome da chave da tabela de hash, snip, é arbitrário. Você pode usar qualquer nome que não esteja reservado, mas não pode usar xmlns.
O cmdlet Select-Xml
obtém o conteúdo do elemento Title de cada trecho. Ele usa o parâmetro Path para especificar o diretório Snippets e o parâmetro Namespace para especificar o namespace na variável $SnippetNamespace
. O valor do XPath parâmetro é o snip:Title
. Os resultados são canalizados para o cmdlet ForEach-Object
, que obtém o título do valor da propriedade InnerXml do nó.
$SnippetNamespace = @{snip = "http://schemas.microsoft.com/PowerShell/Snippets"}
Select-Xml -Path $HOME\Documents\WindowsPowerShell\Snippets -Namespace $SnippetNamespace -XPath "//snip:Title" |
ForEach-Object {$_.Node.InnerXml}
Parâmetros
-Content
Especifica uma cadeia de caracteres que contém o XML a ser pesquisado. Você também pode canalizar strings para Select-Xml
.
Tipo: | String[] |
Position: | Named |
Default value: | None |
Necessário: | True |
Aceitar entrada de pipeline: | True |
Aceitar carateres universais: | False |
-LiteralPath
Especifica os caminhos e nomes de arquivo dos arquivos XML a serem pesquisados. Ao contrário Path, o valor do parâmetro 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.
Tipo: | String[] |
Aliases: | PSPath, LP |
Position: | Named |
Default value: | None |
Necessário: | True |
Aceitar entrada de pipeline: | True |
Aceitar carateres universais: | False |
-Namespace
Especifica uma tabela de hash dos namespaces usados no XML. Use o formato@{<namespaceName> = <namespaceValue>}
.
Quando o XML usa o namespace padrão, que começa com xmlns, use uma chave arbitrária para o nome do namespace. Não é possível usar xmlns. Na instrução XPath, prefixe cada nome de nó com o nome do namespace e dois pontos, como //namespaceName:Node
.
Tipo: | Hashtable |
Position: | Named |
Default value: | None |
Necessário: | False |
Aceitar entrada de pipeline: | False |
Aceitar carateres universais: | False |
-Path
Especifica o caminho e os nomes de arquivo dos arquivos XML a serem pesquisados. Caracteres curinga são permitidos.
Tipo: | String[] |
Position: | 1 |
Default value: | None |
Necessário: | True |
Aceitar entrada de pipeline: | True |
Aceitar carateres universais: | True |
-Xml
Especifica um ou mais nós XML.
Um documento XML será processado como uma coleção de nós XML. Se você canalizar um documento XML para Select-Xml
, cada nó do documento será pesquisado separadamente à medida que passa pelo pipeline.
Tipo: | XmlNode[] |
Aliases: | Node |
Position: | 1 |
Default value: | None |
Necessário: | True |
Aceitar entrada de pipeline: | True |
Aceitar carateres universais: | False |
-XPath
Especifica uma consulta de pesquisa XPath. A linguagem de consulta diferencia maiúsculas de minúsculas. Este parâmetro é obrigatório.
Tipo: | String |
Position: | 0 |
Default value: | None |
Necessário: | True |
Aceitar entrada de pipeline: | False |
Aceitar carateres universais: | False |
Entradas
System.String or System.Xml.XmlNode
Você pode canalizar um caminho ou nó XML para esse cmdlet.
Saídas
Notas
XPath é uma linguagem padrão projetada para identificar partes de um documento XML. Para obter mais informações sobre o idioma XPath, consulte de referência XPath e a seção Filtros de seleção de de seleção de eventos.