这段PowerShell代码有一些问题:
$vmslist = Import-Csv -Path .\vmsList.csv -Delimiter ',' | ForEach-Object {
$_.Servers
$vms = [string]$env:COMPUTERNAME
$currentVms = $_.App_Central
function Check-DiskSpace {
$results = Invoke-Command -ComputerName $currentVms -Credential $Cred -ScriptBlock {
$driveDetails = Get-PSDrive | Where-Object { $_.Name -eq 'D' } | ForEach-Object {
$totalSpace = $_.Free + $_.Used
$name = $_.Root
$vms = $env:COMPUTERNAME
$dDriveFreeSpace = [int]('{0:N2}' -f ($_.Free / 1Gb))
$dDriveUsedSpace = [int]('{0:N2}' -f ($_.Used / 1Gb))
$dDriveTotalSpace = [int]('{0:N2}' -f ($dDriveFreeSpace + $dDriveUsedSpace))
$freePercent = '{0:N1}' -f ( ($dDriveFreeSpace / $dDriveTotalSpace) * 100)
$usedPercent = '{0:N1}' -f ( ($dDriveUsedSpace / $dDriveTotalSpace) * 100)
Write-Host 'Used % of' $_.Root "is $usedPercent%"
Write-Host 'Free % of' $_.Root "is $freePercent%"
}
if($freePercent -le '30') {
$Global:issue = 'Nearly Full!'
}
if ($freePercent -eq '0.0') {
$Global:issue = 'WARNING - FULL CLEAR SPACE NOW!'
}
if($freePercent -gt '30') {
$Global:issue = 'No Issues'
}
Write-Output "$env:COMPUTERNAME, Drive $name, $usedPercent% Full, $Global:issue"
$Global:test3 = @()
$Global:test3 += [PSCustomObject]@{
ComputerName = "$env:COMPUTERNAME"
Drive = "$name"
UsedPercent = "$usedPercent%"
Comments = "$Global:issue"
}
$test3 | Format-Table
}
Export-Excel -Path 'C:\temp\ProcessData.xlsx' -InputObject $results -AutoSize -AutoFilter -Append
return $results
}
}
大家好,
我在导出到Excel时遇到了问题。我想要将
$env:COMPUTERNAME
、驱动器 $name、$usedPercent% Full
、$Global:issue
作为标题与从每个调用命令中提取的数据一起导出。不幸的是,我只能在Excel中得到这个:
然而,当我使用OutFile命令将文本输出到磁盘检查.txt文件时,我得到了以下内容:
这就是我希望数据在我的Excel文件中呈现的方式。