I’ll guide you through two methods for creating a PDF from an Excel file using Power Automate.
- Option 1: Use the free, built-in Power Automate connectors.
- Option 2: Use the Encodian connector, which is free for a limited number of actions and offers additional flexibility.
This step-by-step guide demonstrates how to convert an uploaded Excel file into a PDF, store it in a specific SharePoint document library.
Option 1: Using Free Connectors
The following are the pre-requisites for this method:
The Excel file you want to convert must have a table defined. Here’s how to set it up:
- Open your Excel file in Excel Online or the desktop application.
- Highlight the data you want to include in the PDF.
- Navigate to the Insert tab in the ribbon and select Table.
- In the Create Table dialogue box, ensure the “My table has headers” checkbox is checked (if your data has headers) and click OK.
data:image/s3,"s3://crabby-images/71d96/71d963cab6a9b658492c4724134e3bb5b81bdadd" alt=""
Power Automate Setup
1. Manually Trigger a Flow
To keep things simple, start by creating a new flow in Power Automate. Choose “Instant cloud flow” and select “Manually trigger a flow” as the trigger. This allows you to start the flow manually when needed.
2. List Rows Present in a Table
- Add the “List rows present in a table” action.
- Connect to your Excel file stored in OneDrive or SharePoint.
- Specify the file path and table name. Ensure your Excel file has a defined table with the data you want to convert.
data:image/s3,"s3://crabby-images/f14f4/f14f45a7c6483b012451c26d7b7b1d4f1acfaa95" alt=""
3. Select
The Select action lets you pick the columns you want to export in PDF. You can skip this step if you want to export all columns
data:image/s3,"s3://crabby-images/2039e/2039e13d16beafa91f8d277ec92bdb4be8bb0d8c" alt=""
4. Create HTML Table
- Add the “Create HTML table” action.
- Set the From field to the output of the previous action (
Select
). - Choose “Custom” for the Table Layout to modify the column headers or data formatting as required.
data:image/s3,"s3://crabby-images/bb955/bb9555b001aba80ed8280e047a97fdff4081a982" alt=""
5. Compose Styles
To style your HTML table, add a “Compose” action and define custom CSS styles. For example:
<style>
table {
border-collapse: collapse;
}
table td, table th {
border: 1px solid #AAAAAA;
padding: 3px 10px;
}
table tr:nth-child(even) {
background: #D9E1F2;
}
table thead {
background: #4472C4;
}
table thead th {
font-size: 15px;
font-weight: bold;
color: #FFFFFF;
text-align: left;
}
table tfoot {
font-weight: bold;
}
</style>
data:image/s3,"s3://crabby-images/6f6b1/6f6b1adcf659e71c697e9359e601b2608de47136" alt=""
This ensures the resulting table looks polished when converted to a PDF.
6. Create File
- Add the “Create file” action to generate an HTML file.
- Specify the location (OneDrive or SharePoint) where you want to save the file.
- Use a
.html
extension for the file name (e.g.,myReport.html
). - For the file content, combine the CSS styles and the HTML table using an expression like:
concat(outputs('Compose_Styles'), outputs('Create_HTML_table'))
data:image/s3,"s3://crabby-images/060c4/060c49368859f12b895a48b6f522d0c4ba5129cc" alt=""
7. Convert File
- Add the “Convert file” action.
- Select the previously created HTML file as the source.
- Choose PDF as the conversion format.
- Specify a destination to store the converted file temporarily.
data:image/s3,"s3://crabby-images/52702/52702b8eb26f9699ca7cc87eb89fa003f1e2aba7" alt=""
8. Create File (SharePoint)
- Add another “Create file” action to save the final PDF to your desired location.
- Site address: Your SharePoint site.
- Folder Path: Specify where the PDF should be stored.
- File Name: file name (e.g.,
myRecords.pdf
). - File Content: Dynamic content: “File content” (from the Convert file action).
data:image/s3,"s3://crabby-images/a138a/a138a39f4db6aeb064b031c2ca326ddc5ff27709" alt=""
10. Delete PDF from OneDrive
- Add another Delete file action (OneDrive connector):
- File: Dynamic content: “Id” (from the Create file action in OneDrive).
data:image/s3,"s3://crabby-images/219d5/219d5b9779a19d63ad1166cf8b0ae61e3587f641" alt=""
The full flow
data:image/s3,"s3://crabby-images/48df7/48df73af9b72f4a7f1d3286a45f69cc6895396d1" alt=""
Final Output
data:image/s3,"s3://crabby-images/cebb3/cebb326c417c23d358746292232bd61145ad10a0" alt=""
Option 2: Using Encodian
Encodian is a third-party connector for Power Automate that simplifies the conversion process and adds advanced functionality. While the connector is free for up to 50 credits a month, it can be a great alternative for more complex requirements.
Steps for Using Encodian
- Install Encodian Connector:
- Navigate to the Power Automate connectors gallery and add the Encodian connector to your flow.
- Trigger Setup:
- Follow the same trigger setup as outlined above to detect when an Excel file is uploaded to SharePoint.
- Encodian Convert Excel to PDF Action:
- Add the Encodian Convert Excel to PDF action.
- Configure the action with:
- Source file URL: Dynamic content: “Path” from the trigger.
- Output file format: Select PDF.
data:image/s3,"s3://crabby-images/debf9/debf9496800bfaf1e120ad0c5b704f66c6063068" alt=""
- Store the PDF in SharePoint:
- Add a Create file action to store the converted PDF in your desired SharePoint location.
Encodian offers additional features like customizing the output file and handling large files seamlessly.