查詢 Azure PowerShell 的輸出
每個 Azure PowerShell Cmdlet 的結果都是 Azure PowerShell 物件。 即使 Cmdlet 不是明確的 Get-
作業,也可能會傳回可進行檢查的值,以提供已建立或已修改資源的相關資訊。 大多數的 Cmdlet 會傳回單一物件,但有些會傳回應重複查看的陣列。
通常,您可以使用 Select-Object Cmdlet 從 Azure PowerShell 查詢輸出。 您可以透過 Where-Object 來篩選輸出。
選取簡單屬性
在預設的資料表格式中,Azure PowerShell Cmdlet 不會顯示所有可用的屬性。
您可以使用 Format-List Cmdlet,或透過管線將輸出傳送至 Select-Object -Property *
以取得完整屬性:
Get-AzVM -Name TestVM -ResourceGroupName TestGroup |
Select-Object -Property *
ResourceGroupName : TESTGROUP
Id : /subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/TESTGROUP/providers/Micro
soft.Compute/virtualMachines/TestVM
VmId : 00000000-0000-0000-0000-000000000000
Name : TestVM
Type : Microsoft.Compute/virtualMachines
Location : westus2
LicenseType :
Tags : {}
AvailabilitySetReference :
DiagnosticsProfile :
Extensions : {}
HardwareProfile : Microsoft.Azure.Management.Compute.Models.HardwareProfile
InstanceView :
NetworkProfile : Microsoft.Azure.Management.Compute.Models.NetworkProfile
OSProfile : Microsoft.Azure.Management.Compute.Models.OSProfile
Plan :
ProvisioningState : Succeeded
StorageProfile : Microsoft.Azure.Management.Compute.Models.StorageProfile
DisplayHint : Compact
Identity :
Zones : {}
FullyQualifiedDomainName :
AdditionalCapabilities :
RequestId : 00000000-0000-0000-0000-000000000000
StatusCode : OK
一旦知道您感興趣的屬性名稱後,您可以使用這些屬性名稱搭配 Select-Object
來直接取得這些屬性:
Get-AzVM -Name TestVM -ResourceGroupName TestGroup |
Select-Object -Property Name, VmId, ProvisioningState
Name VmId ProvisioningState
---- ---- -----------------
TestVM 00000000-0000-0000-0000-000000000000 Succeeded
使用 Select-Object
的輸出一律會經過格式化,以顯示要求的資訊。 若要了解如何將格式化當作查詢 Cmdlet 結果的一部份使用,請參閱格式化 Azure PowerShell Cmdlet 的輸出。
選取巢狀屬性
Azure PowerShell Cmdlet 輸出中的某些屬性會使用巢狀物件,例如 Get-AzVM
輸出的 StorageProfile
屬性。 若要從巢狀屬性中取得要檢查的值,需提供值的顯示名稱和完整路徑,以作為 Select-Object
中字典引數的一部份:
Get-AzVM -ResourceGroupName TestGroup |
Select-Object -Property Name, @{label='OSType'; expression={$_.StorageProfile.OSDisk.OSType}}
Name OSType
---- ------
TestVM Linux
TestVM2 Linux
WinVM Windows
每個字典引數都會從物件中選取一個屬性。 要擷取的屬性必須是運算式的一部分。
篩選結果
Where-Object
Cmdlet 可讓您根據任何屬性值 (包括巢狀屬性) 來篩選結果。 下一個範例會示範如何使用 Where-Object
來尋找資源群組中的 Linux VM。
Get-AzVM -ResourceGroupName TestGroup |
Where-Object {$_.StorageProfile.OSDisk.OSType -eq 'Linux'}
ResourceGroupName Name Location VmSize OsType NIC ProvisioningState Zone
----------------- ---- -------- ------ ------ --- ----------------- ----
TestGroup TestVM westus2 Standard_D2s_v3 Linux testvm299 Succeeded
TestGroup TestVM2 westus2 Standard_D2s_v3 Linux testvm2669 Succeeded
您可以使用管道將 Select-Object
和 Where-Object
的結果傳送給彼此。 基於效能目的,我們一律建議將 Where-Object
作業放在 Select-Object
之前:
Get-AzVM -ResourceGroupName TestGroup |
Where-Object {$_.StorageProfile.OsDisk.OsType -eq 'Linux'} |
Select-Object -Property Name, VmID, ProvisioningState
Name VmId ProvisioningState
---- ---- -----------------
TestVM 00000000-0000-0000-0000-000000000000 Succeeded
TestVM2 00000000-0000-0000-0000-000000000000 Succeeded