Kae Travis

Generate a PDF using PowerShell and Microsoft Edge

Posted on by in PowerShell
Tags:

Here we describe how to generate a PDF using PowerShell and Microsoft Edge.

It’s been a while since i knocked this script up, but i recall having issues printing to the PDF printer using System.Drawing.Printing.PrintDocument . It required creating a handler and calculating document dimensions etc. It seemed like too much faff for what should really be a trivial task.

Since I have a background in web technologies I thought about generating some HTML and converting it to a PDF instead. And luckily, Microsoft Edge has a parameter to do just that!

Try running this:

"C:\Program Files (x86)\Microsoft\Edge\Application\msedge.exe" --headless --print-to-pdf=c:\alkane\alkane.pdf --disable-extensions --print-to-pdf-no-header --disable-popup-blocking --run-all-compositor-stages-before-draw --disable-checker-imaging https://www.google.co.uk

This will generate a PDF of the Google homepage and write it to c:\alkane\alkane.pdf ! We can obviously take this a step further by generating our own HTML locally (for a bespoke report, for example) and creating a PDF from that instead!


$reportPath = "c:\alkane\"
$reportname = "alkanereport"
$htmlPath = "$reportPath$reportname.html"
$pdfPath = "$reportPath$reportname.pdf"
if (test-path $pdfPath) {
remove-item $pdfPath -Force
}
if (test-path $htmlPath) {
remove-item $htmlPath -Force
}
#Create sample data
$people = @()
$obj = New-Object PSObject                
$obj | Add-Member -MemberType NoteProperty -Name "Name" -Value "John"
$obj | Add-Member -MemberType NoteProperty -Name "Age" -Value "51"
$obj | Add-Member -MemberType NoteProperty -Name "Gender" -Value "Male"
$people += $obj
$obj = New-Object PSObject                
$obj | Add-Member -MemberType NoteProperty -Name "Name" -Value "Carol"
$obj | Add-Member -MemberType NoteProperty -Name "Age" -Value "36"
$obj | Add-Member -MemberType NoteProperty -Name "Gender" -Value "Female"
$people += $obj
$obj = New-Object PSObject                
$obj | Add-Member -MemberType NoteProperty -Name "Name" -Value "Laura"
$obj | Add-Member -MemberType NoteProperty -Name "Age" -Value "26"
$obj | Add-Member -MemberType NoteProperty -Name "Gender" -Value "Female"
$people += $obj
$obj = New-Object PSObject                
$obj | Add-Member -MemberType NoteProperty -Name "Name" -Value "Peter"
$obj | Add-Member -MemberType NoteProperty -Name "Age" -Value "72"
$obj | Add-Member -MemberType NoteProperty -Name "Gender" -Value "Male"
$people += $obj
#Generate HTML for PDF
$html = "<html<head>"
$html = $html + "<style>"
$html = $html + "body {"
$html = $html + "    font-family:arial;"
$html = $html + "    font-size:14px;"
$html = $html + "    margin:0px;"
$html = $html + "}"
$html = $html + "table, th, td {"
$html = $html + "    font-size:14px;"
$html = $html + "    border: 1px solid black;"
$html = $html + "    border-collapse: collapse;"
$html = $html + "    text-align:center;"
$html = $html + "    padding: 5px 40px 5px 40px;"
$html = $html + "}"
$html = $html + "th {"
$html = $html + "    background-color: #618a2a;"
$html = $html + "    color: #fff;"
$html = $html + "}"
$html = $html + ".header {"
$html = $html + "    text-align:left;"
$html = $html + "    background-color: #618a2a;"
$html = $html + "}"
$html = $html + ".red {"
$html = $html + "    background-color: red;"
$html = $html + "}"
$html = $html + ".wrapper {"
$html = $html + "    margin:20px;"
$html = $html + "}"
$html = $html + ".logo {"
$html = $html + "    height: 40px;"
$html = $html + "    margin: 20px 0px 20px 20px;"
$html = $html + "}"
$html = $html + "p {"
$html = $html + "    margin: 0px 0px 30px 0px;"
$html = $html + "}"
$html = $html + "</style>"
$html = $html + "</head><body>"
$html = $html + "<div class='header'>"
$html = $html + "<img class='logo' src=''/>"
$html = $html + "</div>"
$html = $html + "<div class='wrapper'>"
$html = $html + "<h1>Monthly Report</h1>"
$html = $html + "<p>Please find below your report.</p>"
$html = $html + "<table>"
$html = $html + "<tr><th>Name</th><th>Age</th><th>Gender</th></tr>"
foreach($person in $people) {
$html = $html + "<tr>"
$html = $html + "<td>" + $person.Name + "</td>"
$html = $html + "<td>" + $person.Age + "</td>"
$html = $html + "<td>" + $person.Gender + "</td>"
$html = $html + "</tr>"
}
$html = $html + "</div>"
$html = $html + "</table></body></html>"
$html | Out-File $htmlPath -Force
Start-Process "msedge.exe" -ArgumentList @("--headless","--print-to-pdf=""$pdfPath""","--disable-extensions","--print-to-pdf-no-header","--disable-popup-blocking","--run-all-compositor-stages-before-draw","--disable-checker-imaging", "file:///$htmlPath")
#wait for PDF creation
while (!(Test-Path $pdfPath)) { Start-Sleep 2 }
#remove HTML file
if (test-path $htmlPath) {
remove-item $htmlPath -Force
}
#open PDF
Start-Process $pdfPath

The above example creates some sample data (an array of people’s name, age and gender), writes it to a HTML file with custom CSS styling, generates a PDF from the HTML file using Microsoft Edge, and then removes the HTML file.

Generate a PDF using PowerShell and Microsoft Edge
Generate a PDF using PowerShell and Microsoft Edge

Leave a Reply