PoshCode Archive  Artifact [403c32cfbc]

Artifact 403c32cfbcddb10f7019be6f89393823b11e9cbe629ee22bfcb1a0292d2381c7:

  • File This-newer-version-of-the-.ps1 — part of check-in [7200ab4da3] at 2018-06-10 14:01:00 on branch trunk — This newer version of the ExBPA only creates HTML based reports for each server. This setup made the reports difficult to compile and notarize. So I made a parser to read the HTML and convert the pertinent data into CSV files. (user: Josh Wortz size: 2746)

# encoding: ascii
# api: powershell
# title: 
# description: This newer version of the ExBPA only creates HTML based reports for each server. This setup made the reports difficult to compile and notarize. So I made a parser to read the HTML and convert the pertinent data into CSV files.
# version: 0.1
# type: script
# author: Josh Wortz
# license: CC0
# x-poshcode-id: 5768
# x-archived: 2015-03-23T13:08:48
#
#
<#
.SYNOPSIS
Converts Microsoft Office 365 Best Practices Analyzer HTML reports to CSV.

.DESCRIPTION 
Converts Microsoft Office 365 Best Practices Analyzer HTML reports to CSV.

.PARAMETER FileLocation
Provide the path to one or many HTML files.

.EXAMPLE 
 ConvertExBPATo-CSV -FileLocation (Get-ChildItem *.html)


.NOTES
Author: Josh Wortz
Date Created: 3/3/2015

#>
param(
    [ValidateScript({%{Test-Path $_ -PathType 'Leaf'}})][string[]]$FileLocation

)

function ParseBPA([ValidateScript({%{Test-Path $_ -PathType 'Leaf'}})][string[]]$Files)
{
    
    $detailsRegx = "<div[^>]*>(.*?)<br \/><br \/>"
    $notesRegx = "<img src[^>]*\/>(.*?)<br \/>"

    [array]$HTMLArray = ([string](Get-Content $Files)).replace("<div", "`n<div") -split "`n" 

    #[array]$htmlarray = $newHTML -split "`n"
    [array]$report = $null


    foreach ($line in $htmlarray)
    {
        if ($line -match "<div onclick")
            {
                 [string]$note =([regex]::match($line, $notesregx).Groups[1].Value)
                $Object = New-Object PSObject
                
                $Object | add-member Noteproperty Title $note
                
                if ($line -match "img_Warning")
                    {
                        $type= "Warning"
                    }
                    elseif ($line -match "img_Error")
                    {
                        $type = "Error"
                    }
                    elseif ($line -match "img_Info")
                    {
                        $type = "Informational"
                    }
                    else
                    {
                        $type = "Passed"
                    }
                    
                
                $Object | add-member Noteproperty ErrorType $type
            
            }
        elseif($line -match "hidden_Section" -and !($line -match "<?xml version="))
            {
                [string]$note = ([regex]::match($line, $detailsRegx).Groups[1].Value)  
                $Object | add-member Noteproperty Details $note
                
                $report += $object
            }


    }
    $report

}


Get-ChildItem $FileLocation | %{ParseBPA -Files $_ | export-csv -NoTypeInformation "$_.csv"}