如何使用powershell仅对第二列值求和?

use*_*902 3 powershell powershell-2.0 powershell-1.0 powershell-3.0

sharesize.ps1

echo " "
$date1 = Get-Date
Write-Host -foreground Yellow -background Black "Script Started at $date1"

$path = "\*"

get-childitem $path | where {$_.PSIsContainer} | foreach { 

$size = (Get-ChildItem $_ -recurse | where {!$_.PSIsContainer} | Measure-Object -Sum Length).Sum 

$size = "{0:N2}" -f ($size / 1MB) + " MB"

$obj = new-object psobject 
add-member -inp $obj noteproperty Path $_.fullName 
add-member -inp $obj noteproperty "Size(MB)" $size 
[array]$report += $obj
}


#display the table
$a = "<style>"
$a = $a + "BODY{background-color:green;}"
$a = $a + "TABLE{border-width: 1px;border-style: solid;border-color: black;border-collapse: collapse;}"
$a = $a + "TH{border-width: 2px;padding: 0px;border-style: solid;border-color: black;background-color:Yellow; font-family: Arial; font-size: 12pt}"
$a = $a + "TD{border-width: 2px;padding: 2px 6px 2px 3px;border-style: solid;border-color: black;background-color:Azure; font-family: Arial; font-size: 10pt}"
$a = $a + "</style>"


$report | Sort 'Size' -Descending | ConvertTo-HTML -head $a -title "Process Information" -body "<H2>Service Information</H2>"| Out-File -Append c:\temp\folder.html


$date2 = Get-Date
echo " "
Write-Host -foreground Yellow -background Black "Script Ended at $date2"
echo " "
Run Code Online (Sandbox Code Playgroud)

以上代码对我很有帮助,非常感谢以下帮助.

这里我的要求是添加第二列的总和并将输出附加到上面的代码输出html(c:\ temp\folder.html)的最后一行,因为,


       Path                   | Size(MB)
Run Code Online (Sandbox Code Playgroud)
 C:\NVIDIA\Displaydriver      |  400 MB
  *                           |  860 MB
  *                           |  100 MB
  *                           |   * MB
  *                           |   * MB
Run Code Online (Sandbox Code Playgroud)
       Total                  |  1000 MB(sum of all numbers in 2nd column values)
Run Code Online (Sandbox Code Playgroud)

我还需要将第二列值和总行对齐到CENTER.

请帮忙

Kei*_*ill 8

总结大小这样做​​:

$totalSize = ($report | Measure-Object 'Size(MB)' -Sum).Sum
Run Code Online (Sandbox Code Playgroud)