【问题标题】:List hard Disk Information on remote computers within a domain列出域内远程计算机上的硬盘信息
【发布时间】:2015-03-30 17:17:34
【问题描述】:

我正在尝试获取硬盘信息列表。目前我只希望列表显示每台计算机包含的硬盘型号。

我有下面的

Get-WMIObject win32_diskdrive -computer (Get-Content C:\Temp\DiskDrives\Computers.txt) | Select model | Export- CSV "C:\Temp\DiskDrives\Machines.csv" 

computers.txt 文件包含代码一一经过的计算机列表。以上工作到一定程度,它将列出它可以为机器找到的驱动器,但 csv 文件的格式不太好。

可以格式化 csv 以包含 txt 文件中的计算机名称吗?也只能选择硬盘而不是usb、sd设备等?

感谢任何想法/建议。

非常感谢, 克里斯

【问题讨论】:

  • psexecinvoke-command你可以使用powershell invoke-command和使用管道和out-file c:\example.csv

标签: powershell powershell-3.0


【解决方案1】:

只需选择 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的力量。

【讨论】:

  • 感谢您提供的信息和详细信息。这就是我一直在寻找的并且效果很好,数据的格式使它更容易阅读。感谢您所做的努力。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2013-01-04
  • 1970-01-01
  • 2011-10-09
  • 1970-01-01
  • 1970-01-01
  • 2014-11-17
相关资源
最近更新 更多