只需选择 SystemName 属性,您就会得到这样的结果。
Get-WMIObject win32_diskdrive -computer (Get-Content C:\Temp\DiskDrives\Computers.txt) | `
Select SystemName,model
>SystemName Model Size(GB)
---------- ----- --------
BEHEMOTH OCZ-VERTEX PLUS R2 58
BEHEMOTH JetFlash Transcend 32GB USB Device 29
BEHEMOTH INTEL SSDSC2CT180A3 168
BEHEMOTH SAMSUNG HD103SJ 932
BEHEMOTH OCZ-VERTEX 60
BEHEMOTH ST3000DM001-1CH166 2795
BEHEMOTH OCZ-VERTEX PLUS R2 58
BEHEMOTH JetFlash Transcend 32GB USB Device 29
BEHEMOTH INTEL SSDSC2CT180A3 168
BEHEMOTH SAMSUNG HD103SJ 932
BEHEMOTH OCZ-VERTEX 60
BEHEMOTH ST3000DM001-1CH166 2795
一旦您针对多台计算机运行 WMI 查询,您还会获得 SystemName 参数,这使这变得很容易!
请注意,在上面的结果中,我有一个名为 Transcend 的小驱动器,它是一个 32 GB USB 3 闪存驱动器。您提到只想包含固定磁盘,而不是 USB,因此为此我们只需添加一个Where 语句,如下所示:
PS C:\> Get-WMIObject win32_diskdrive -ComputerName behemoth,localhost |
Where-Object MediaType -eq 'Fixed hard disk media' | Select SystemName,Model
>SystemName Model Size(GB)
---------- ----- --------
BEHEMOTH OCZ-VERTEX PLUS R2 58
BEHEMOTH INTEL SSDSC2CT180A3 168
BEHEMOTH SAMSUNG HD103SJ 932
BEHEMOTH OCZ-VERTEX 60
BEHEMOTH ST3000DM001-1CH166 2795
BEHEMOTH OCZ-VERTEX PLUS R2 58
BEHEMOTH INTEL SSDSC2CT180A3 168
BEHEMOTH SAMSUNG HD103SJ 932
BEHEMOTH OCZ-VERTEX 60
BEHEMOTH ST3000DM001-1CH166 2795
奖励点,如果您想以 GB 为单位显示磁盘大小,请将您的 select 语句更改为此,该语句使用计算属性创建一个名为 Size(GB) 的新列,并使用 $_.Size 属性除以来填充它1GB 整数(整数)形式:
Select SystemName,Model,@{Name='Size(GB)';Exp={$_.Size /1gb -as [int]}}`
已完成单线
只需将您的 Export-CSV 添加到管道的末尾即可获得完整的一个 -
像这样的衬里应该会给你你正在寻找的结果:
Get-WMIObject win32_diskdrive -computer (Get-Content C:\Temp\DiskDrives\Computers.txt) |
Where-Object MediaType -eq 'Fixed hard disk media' |
Select SystemName,Model,@{Name='Size(GB)';Exp={$_.Size /1gb -as [int]}} |
Export- CSV "C:\Temp\DiskDrives\Machines.csv"
啊,PowerShell 的威力。