New "Analyze-This" example

This commit is contained in:
jhoneill
2019-05-03 12:45:30 -07:00
parent 978e8d38b5
commit f20a9de3df

View File

@@ -1,24 +1,50 @@
$xlfilename = $pwd.path -replace "^.*\\(.*?)\\(.*?)$", '$1-$2.xlsx' <#
$xlpath = Join-Path -Path $env:TEMP -ChildPath $xlfilename .Synopsis
Remove-Item -Path $xlpath -ErrorAction SilentlyContinue
$ScriptAnalyzerResults = Invoke-ScriptAnalyzer . #>
[CmdletBinding()]
param (
[parameter(ValueFromPipeline = $true)]
$Path = $PWD,
$xlfile = "$env:TEMP\ScriptAnalyzer.xlsx",
$ChartType = 'BarClustered' ,
[switch]$Quiet
)
$xlPkg = $ScriptAnalyzerResults | Group-Object -Property RuleName -NoElement | Sort-Object -Property Name | begin {
Select-Object -Property Name,Count | Remove-Item -Path $xlfile -ErrorAction SilentlyContinue
Export-Excel -Path $xlpath -WorksheetName Summary -AutoSize -PassThru $xlparams = @{
Path = $xlfile
$params = @{ WorksheetName = 'FullResults'
WorksheetName = 'FullResults' AutoSize = $true
AutoSize = $true AutoFilter = $true
AutoFilter = $true Activate = $true
IncludePivotTable = $true Show = (-not $Quiet)
Activate = $true }
PivotRows = 'Severity', 'RuleName' $pivotParams = @{
PivotData = @{RuleName = 'Count' } PivotTableName = 'BreakDown'
IncludePivotChart = $true PivotData = @{RuleName = 'Count' }
ChartType = 'BarClustered' PivotRows = 'Severity', 'RuleName'
Show = $true PivotColumns = 'Location'
PivotTotals = 'Rows'
}
$dirsToProcess = @()
}
process {
if ($path.fullName) {$dirsToProcess += $path.fullName}
elseif ($path.path) {$dirsToProcess += $path.Path}
else {$dirsToProcess += $path}
} }
Export-Excel -ExcelPackage $xlpkg -InputObject $ScriptAnalyzerResults @params end {
$pivotParams['-PivotChartDefinition'] = New-ExcelChartDefinition -ChartType $chartType -Column $dirsToProcess.Count -Title "Script analysis" -LegendBold
$xlparams['PivotTableDefinition'] = New-PivotTableDefinition @pivotParams
$dirsToProcess | ForEach-Object {
$dirName = (Resolve-Path -Path $_) -replace "^.*\\(.*?)\\(.*?)$", '$1-$2'
Write-Progress -Activity "Running Script Analyzer" -CurrentOperation $dirName
Invoke-ScriptAnalyzer -Path $_ -ErrorAction SilentlyContinue |
Add-Member -MemberType NoteProperty -Name Location -Value $dirName -PassThru
} | Export-Excel @xlparams
Write-Progress -Activity "Running Script Analyzer" -Completed
}