Merge PDFs under a directory using PowerShell, CoolOrange Module, and PDFSharp .NET extension
-
Download CoolOrange's MergePDF PowerShell module and accompanying PDFSharp DLL from: https://support.coolorange.com/support/solutions/articles/22000211000-how-to-merge-multiple-pdf-with-pdfsharp-and-powershell
-
Modify the module to adjust the paths to where you installed the CoolOrange code.
-
Also modify the baseDir and destDir variables to control where you want to save the PDFs.
Note that there is also a standalone test script, which takes no parameters. It would need all the variables modified.
-
After installation (see above), open cmd.exe
-
Run the following command:
powershell.exe -ExecutionPolicy Bypass -Command "& 'C:\Users\USERNAME\Software\pdfMerge\pdfMergeRecurse.ps1' -srcDir C:\pdfSrc -destDir C:\pdfDest"
where the first part of the path is where you've installed.
-
After installation (see above), open PowerShell (command line or ISE).
-
Set to be allowed to run in PowerShell by first running the command below. This allows for scripts to be run in process scope. See http://9to5it.com/bypass-the-powershell-execution-policy/
Set-ExecutionPolicy Bypass -Scope Process
You may need to run PowerShell as Administrator for this to work.
-
Load the module.
-
Then, set the variables as needed. Example:
$srcDir = "C:\srcDir"
$destDir = "C:\destDir"
MergePDFRecurse $srcDir $destDir
Note that if $destDir does not exist, it will be created.
- May not work with extremely long paths (need to test)
- Some underlying code (not mine) calls an AddLog cmdlet that may not exist on your machine. It will throw an error per PDF to the PS command line. This is harmless, I think - probably just happens if you don't have Visual Studio.
- Make the paths to the coolOrange code configurable as optional parameters. Otherwise, use defaults in source.
- Include a test script for the MergePDFRecurse which could be invoked from command line as a one liner. This would be useful for batch executions.
- Make it confirm whether the srcDir exists.
- Try/catch on errors
- Logging