共用方式為


Select-Xml

尋找 XML 字串或檔案中的文字。

語法

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

Select-Xml Cmdlet 可讓您使用 XPath 查詢來搜尋 XML 字串和檔中的文字。 輸入 XPath 查詢,並使用 ContentPathXml 參數來指定要搜尋的 XML。

範例

範例 1:選取 AliasProperty 節點

這個範例會取得 Types.ps1xml中的別名屬性。 如需此檔案的相關信息,請參閱 about_Types.ps1xml

第一個命令會將 $Path 變數中 Types.ps1xml 檔案的路徑儲存。

第二個命令會將 XML 路徑儲存至 $XPath 變數中的 AliasProperty 節點。

Select-Xml Cmdlet 會從 Types.ps1xml 檔案中取得 XPath 語句所識別的 AliasProperty 節點。 此命令會使用管線運算符 (|) 將 AliasProperty 節點傳送至 Select-Object Cmdlet。 ExpandProperty 參數會展開 Node 物件,並傳回其 NameReferencedMemberName 屬性。

$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

結果會顯示 Types.ps1xml 檔案中每個別名屬性的 Name 和 ReferencedMemberName。 例如,有一個 Count 屬性是 Length 屬性的別名。

範例 2:輸入 XML 檔

此範例示範如何使用 XML 參數,將 XML 檔提供給 Select-Xml Cmdlet。

Get-Content Cmdlet 會取得 Types.ps1xml 檔案的內容,並將它儲存在 $Types 變數中。 [xml] 會將變數轉換成 XML 物件。

Select-Xml Cmdlet 會取得 Types.ps1xml 檔案中 MethodName 節點。 此命令會使用 Xml 參數來指定 $Types 變數中的 XML 內容,以及 XPath 參數,以指定 MethodName 節點的路徑。

[xml]$Types = Get-Content $Pshome\Types.ps1xml
Select-Xml -Xml $Types -XPath "//MethodName"

範例 3:搜尋 PowerShell 說明檔

此範例示範如何使用 Select-Xml Cmdlet 來搜尋 PowerShell XML 型 Cmdlet 說明檔。 在此範例中,我們將搜尋 Cmdlet 名稱,以作為每個說明檔的標題,以及說明檔的路徑。

$Namespace 變數包含哈希表,代表用於說明檔的 XML 命名空間。

$Path 變數包含PowerShell說明檔的路徑。 如果計算機上此路徑中沒有任何說明檔,請使用 Update-Help Cmdlet 下載說明檔。 如需可更新說明的詳細資訊,請參閱 about_Updatable_Help

Select-Xml Cmdlet 會尋找檔案中任何位置的 Command:Name 元素,以搜尋 XML 檔案中是否有 Cmdlet 名稱。 結果會儲存在 $Xml 變數中。 Select-Xml 會傳回 SelectXmlInfo 物件,該物件具有 Node 屬性,這是 System.Xml.XmlElement 物件。 Node 屬性具有 InnerXML 屬性,其中包含擷取的實際 XML。

$Xml 變數會管線傳送至 Format-Table Cmdlet。 Format-Table 命令會使用匯出屬性來取得 $Xml 變數中每個物件的 Node.InnerXML 屬性、修剪文字前後的空格符,並在數據表中顯示,以及來源檔案 Path

$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
...

範例 4:輸入 XML 的不同方式

此範例示範將 XML 傳送至 Select-Xml Cmdlet 的兩種不同的方式。

第一個命令會在 $Xml 變數中儲存包含 XML 的 here-string。 如需 here-strings 的詳細資訊,請參閱 about_Quoting_Rules

Select-Xml 會使用 Content 參數,在 $Xml 變數中指定 XML。

第三個命令與第二個命令相同,不同之處在於 tt 會使用管線運算子 (|) 將 $Xml 變數中的 XML 傳送至 Select-Xml Cmdlet。

$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

範例 5:使用預設 xmlns 命名空間

此範例示範如何使用 Select-Xml Cmdlet 搭配使用預設 xmlns 命名空間的 XML 檔。 此範例會取得 Windows PowerShell ISE 使用者建立代碼段檔案的標題。 如需代碼段的相關信息,請參閱 New-IseSnippet

$SnippetNamespace 變數包含代碼段 XML 檔案所使用的預設命名空間哈希表。 哈希表值是代碼段 XML 中的 XMLNS 架構 URI。 哈希表索引鍵名稱 為任意。 您可以使用任何未保留的名稱,但無法使用 xmlns

Select-Xml Cmdlet 會取得每個代碼段 Title 元素的內容。 它會使用 Path 參數來指定 Snippets 目錄和 Namespace 參數,以指定 $SnippetNamespace 變數中的命名空間。 XPath 參數的值是 snip:Title。 結果會透過管線傳送至 ForEach-Object Cmdlet,此 Cmdlet 會從節點 InnerXml 屬性的值取得標題。

$SnippetNamespace = @{snip = "http://schemas.microsoft.com/PowerShell/Snippets"}

Select-Xml -Path $Home\Documents\WindowsPowerShell\Snippets -Namespace $SnippetNamespace -XPath "//snip:Title" |
    ForEach-Object {$_.Node.Innerxml}

參數

-Content

指定要搜尋之 XML 的字串。 您也可以使用管線將字串傳送至 Select-Xml

類型:String[]
Position:Named
預設值:None
必要:True
接受管線輸入:True
接受萬用字元:False

-LiteralPath

指定要搜尋之 XML 檔案的路徑和檔名。 不同於 PathLiteralPath 參數的值會與輸入時完全相同。 不會將任何字元解譯為通配符。 如果路徑包含逸出字元,請以單引弧括住它。 單引號會告知PowerShell不要將任何字元解譯為逸出序列。

類型:String[]
別名:PSPath, LP
Position:Named
預設值:None
必要:True
接受管線輸入:True
接受萬用字元:False

-Namespace

指定 XML 中使用的命名空間哈希表。 使用格式@{<namespaceName> = <namespaceValue>}

當 XML 使用以 xmlns 開頭的預設命名空間時,請使用命名空間名稱的任意索引鍵。 您無法使用 xmlns。 在 XPath 語句中,在每個節點名稱前面加上命名空間名稱和冒號,例如 //namespaceName:Node

類型:Hashtable
Position:Named
預設值:None
必要:False
接受管線輸入:False
接受萬用字元:False

-Path

指定要搜尋之 XML 檔案的路徑和檔名。 允許通配符。

類型:String[]
Position:1
預設值:None
必要:True
接受管線輸入:True
接受萬用字元:True

-Xml

指定一或多個 XML 節點。

XML 檔會當做 XML 節點的集合來處理。 如果您使用管線將 XML 檔傳送至 Select-Xml,則每個文件節點將會在管線中個別搜尋。

類型:XmlNode[]
別名:Node
Position:1
預設值:None
必要:True
接受管線輸入:True
接受萬用字元:False

-XPath

指定 XPath 搜尋查詢。 查詢語言會區分大小寫。 這是必要參數。

類型:String
Position:0
預設值:None
必要:True
接受管線輸入:False
接受萬用字元:False

輸入

System.String or System.Xml.XmlNode

您可以使用管線將路徑或 XML 節點傳送至此 Cmdlet。

輸出

SelectXmlInfo

備註

XPath 是一種標準語言,設計用來識別 XML 檔的部分。 如需 XPath 語言的詳細資訊,請參閱 XPath 參考事件選取範圍的選取範圍篩選一節。