Merging Documents Using Microsoft Power Automate
data:image/s3,"s3://crabby-images/279b7/279b70c493ddc64e76909dd960a5a8e204131fb4" alt="Header image dramatizing multiple folders coming together in blissful harmony…"
One of the most powerful things that Microsoft Power Automate is the ability to create workflows and then modify them later for completely different purposes. By letting citizen developers piece together different building blocks, the possibilities for what can be done become nearly endless. As an example of how flexible and powerful this platform can be, let’s look at two examples of how the platform can be used to automate the process of merging PDFs — using Adobe Document Services of course!
First Example — A Static Merge
To start off, we will build a workflow that is static in nature. By that we mean it would be manually started, scan a folder of PDFs, merge them, and just email the result. While this isn’t a realistic process, the goal here is to demonstrate an example Power Automate and PDF Services flow.
- Begin by creating a new flow and selecting “Instant cloud flow”:
data:image/s3,"s3://crabby-images/7d07e/7d07eb1d6b8ef535a4da4b90d33f7719d2b88a3f" alt="Making a new flow with “Instant cloud flow”"
2. In the next screen, give the workflow a name and select the manual trigger:
data:image/s3,"s3://crabby-images/b1ce8/b1ce8aaf4eb921c6b0433e2094f48116d6ac0ab9" alt="Naming the flow and selecting the trigger"
3. For a test, use a folder in a SharePoint account that will only contain PDFs. The next step is tells Power Automate to read that folder. Click on “New Step”, and select the “List folder” action from the SharePoint application. After adding it, select the site and folder.
data:image/s3,"s3://crabby-images/9fe8d/9fe8de7b2b417484e9d04ea91d2c85dadd1e9f72" alt="Selected site and folder from SharePoint"
4. To merge a list of PDFs, we need to make that list. To do that, use a variable to store the files found in SharePoint. Click on “New step” again and select “Initialize variable”. Name the variable files
and select the "Array" type.
data:image/s3,"s3://crabby-images/7012e/7012e93e56939418a87051fe1e7bddb1a3a41ab7" alt="Setting up the files array variable"
5. Now that we have an array, the next step is to loop over the list of files we got previously and get the contents. For each, we’re also going to need to append them to our array. Once again, add a step, and select “Apply to each”. When prompted to select the output from previous steps, select “body” from the “List folder” step. Now we need to build up that loop.
6. Inside of that “Apply to each”, select “Add an action”, and then “Get file content” from the SharePoint app. The site is the same as previously selected, but for “File identifier”, select the “Id” value from the set of items currently being looped over.
data:image/s3,"s3://crabby-images/be883/be883f8d2f42e0ec47007c8cef0d6df84c997e29" alt="Partially done with our loop action"
7. After getting the file content, the next step is to append it to the array. Ensuring you are still in “Apply to each”, hit “Add an action” and select “Append to array variable”. For Name, Power Automate should suggest files
as your only array variable in the flow. For the value, select "File Content" from the "Get file content" step. Here's the completed loop action:
data:image/s3,"s3://crabby-images/1e3ce/1e3ce03b81eccc4a10e57e1fc4b24c1b780926ac" alt="Final loop action"
8. Ok! We’re finally ready to do the merge. Select “New step”, and then select the “Merge PDF” step. We need to provide a name for the merged PDF and as this is just a “test” workflow, go with the appropriately named merged.pdf
. When editing the Merge PDF action, it defaults to asking you to select the first file with the option to add more manually. This is not what we want as the list of files is dynamic. On the right side, click the little box that has the tooltip, "Switch to input entire array":
data:image/s3,"s3://crabby-images/23290/232909d6cc17ebe45f155cb1f35198c8897226bc" alt="Indicator to switch to inputting the entire array"
In that view, select files
from your variables:
data:image/s3,"s3://crabby-images/e95a1/e95a107650ffb062a67bab0f6be4003f14318aca" alt="Selecting files for the array"
Note that if you see “[“ or “]”, be sure to remove that, and any white space before and after the “files” marker.
9. As a final step, and to check the result, add a step that will email you the result. Hit “New step” again and select “Send email with options”. Entered your email address in the “To” portion and use a “Subject” of “Testing PDF Merge”. Click “Show advanced options”. In the advanced settings note the two fields for an attachment — “Attachments Name — 1” and “Attachments Content — 1”.
For the name, select “PDF File Name” from Merge PDFs. For the content, select “PDF File Content”.
data:image/s3,"s3://crabby-images/30e9b/30e9b9392777c97bb7444a66f15d08da616496a9" alt="Mail step"
Run the flow again and you will end up with the merged PDF in email!
Second Example — Dynamic Merging
In the next example, let’s create a flow that’s a bit more realistic. This flow will monitor a SharePoint folder for PDF files, and when one is found, it will merge it with a boilerplate legal document and then copy it to a destination folder. There will be three SharePoint resources involved:
- The folder that will be monitored (
input
) - The PDF with the boilerplate legal documents (
legal.pdf
) - An output folder (
output
) to store results.
- As before, begin by creating a new flow, but this time it will be an automated flow. For the trigger, select “When a file is created in a folder” from SharePoint:
data:image/s3,"s3://crabby-images/66ee4/66ee472e59fb9a1a9a9cb3674dd3469f89a55fbc" alt="Creating the new automated flow"
2. In the trigger, select a site and a folder to monitor.
data:image/s3,"s3://crabby-images/e7f93/e7f93e49578001a5a21066a494a7b9f0d8796afa" alt="Selected site and folder for the SharePoint trigger"
3. Add a new step, and as before, select SharePoint “Get file content” step. The site will be the same as before, but for the file identifier, select x-ms-file-id
from the trigger.
data:image/s3,"s3://crabby-images/2db69/2db69d1dd4fa11db18d1621ef04bef4c47590da9" alt="Configured step to get file contents"
4. Next, add another step using “Get file content”, except this time select the legal PDF document.
data:image/s3,"s3://crabby-images/96c65/96c654e027e5f9c1e92b5dd570f43b615131dd8c" alt="Getting the legal document"
5. At this point we’ve got two files from SharePoint — the newly updated one and the legal document. Next, add a “Merge PDFs” step again. For the name, use the x-ms-file-name-encoded
value from the original trigger, and this time we can specify the content for both the first and second items to merge.
Now it’s important that the order is correct. For this demo, assume the legal text should go in front of the rest of the PDF. For your flow, you may want the opposite. Just keep in mind that the action is going to do what you tell it to do. For our flow, “Get file content 2” got the legal PDF. “Get file content” got the new PDF. Select the second one first and the first one second. Hopefully, that isn’t too confusing, but if you end up with a result that’s the reverse of what you want, that’s where you will want to check your work.
data:image/s3,"s3://crabby-images/2f5ef/2f5ef6cea6469f65b29cfaead287681229f6584f" alt="Selecting the inputs for the Merge operation"
6. The final step is copying the result back up to SharePoint. Add a new step, and select “Create file” from the SharePoint section. After selecting the site and output folder, the file name and file content can both come from the Merge PDFs action:
data:image/s3,"s3://crabby-images/c252f/c252fe43a975b7b02dbe2ff88ad54152173d1642" alt="Create file step"
7. And that’s it. Test the flow, drop a PDF in the input folder, and you’ll see your flow execute and save the merged result at the end.
Next Steps
The annual Microsoft Build conference is being held this week and Adobe will have a presence there. Please visit our showcase for information about our work with Microsoft and our Build sessions.
We’ve recently added new documentation to help people make use of Adobe PDF Services and Microsoft Power Automate. You can begin with Getting credentials for Microsoft Power Automate, which will help you set up and configure your credentials for use with Power Automate. Then follow up with Create your first flow in Microsoft Power Automate. Finally, be sure to reach out on our forums with any questions you may have.