Power Apps Export To Excel As A CSV File
Excel is one of the most popular business apps in the world so when people see data inside of Power Apps its natural for them to ask “can I download it to Excel?” The answer is yes, definitely! With a little bit of help from Power Automate, Power Apps can transform table data from a datasource or a collection into a CSV which the user can open in Excel.
In this article I will show you how to use Power Apps to export a file to Excel.
Table of Contents:
Introduction: The Car Sales Inventory App
Setup The SharePoint List
Insert A Table To Display Information In The App
Preparing A JSON Sample For The Export To Excel Flow
Creating The Export To Excel Flow
Connect The 'Export To Excel' Flow In Power Apps
Download The CSV File And Open In Excel
Introduction: The Car Sales Inventory App
The Car Sales Inventory app is used by salespeople at a car dealership to create a report on all the cars currently in-stock. They open the app to the inventory screen, click on a button to download and then open the CSV file in Excel.
Setup The SharePoint List
Create a new SharePoint list called Car Sales Inventory with the following columns:
- Year (number)
- Make (single-line text)
- Model (single-line text)
- Color (single-line text)
- Location (single-line text)
- Cost (number)
Include this data in the list:
Year | Make | Model | Color | Location | Cost |
2000 | Honda | Accord | Orange | Houston | 15,242.74 |
1998 | Oldsmobile | Aurora | Orange | Austin | 14,691.91 |
1984 | Maserati | Quattroporte | Pink | Houston | 7,568.83 |
2011 | Chevrolet | Malibu | Turquoise | Fort Worth | 22,711.39 |
2006 | Mercedes-Benz | G-Class | Crimson | Fort Worth | 13,949.48 |
1985 | Ford | Laser | Green | Dallas | 34,159.31 |
2009 | Kia | Spectra | Fuscia | Dallas | 29,023.15 |
1996 | Dodge | Ram Van 3500 | Yellow | San Antonio | 24,883 |
1985 | Buick | Century | Orange | Fort Worth | 33,778.10 |
2009 | Mercedes-Benz | S-Class | Blue | Fort Worth | 27,039.57 |
Insert A Table To Display Information In The App
Open Power Apps Studio and create a new app from blank. Place a label at the top of the screen showing the title.
Add the Car Sales Inventory SharePoint list as a datasource.
Then insert a data table with and update the Items property to ‘Car Sales Inventory‘ to show the list of cars available for sale.
Preparing A JSON Sample For The Export To Excel Flow
The CSV file will be created in Power Automate so we need a way to pass data from the table into a Flow. We will do this by converting the data into a JSON. To prepare for making the Flow we need to generate a sample of the JSON being passed. Create a new blank screen and place a button on it.
Put this code in the OnSelect property of the button. The JSON function converts table data, whether from a datasource or from a collection, into text formatted as a JSON.
Set(
varJSONCars,
JSON(
ShowColumns(
FirstN('Car Sales Inventory', 3),
"year",
"make",
"model",
"color",
"location",
"cost"
),
JSONFormat.IndentFour
)
)
Then insert a label beside the button and put this code in the Text property.
varJSONCars
The label will show some JSON formatted text like this. That’s all for now, we are ready to create our flow. We will use this JSON sample in a few moments.
[
{
"color": "Orange",
"cost": 15242.74,
"location": "Houston",
"make": "Honda",
"model": "Accord",
"year": 2000
},
{
"color": "Orange",
"cost": 14691.91,
"location": "Austin",
"make": "Oldsmobile",
"model": "Aurora",
"year": 1998
},
{
"color": "Pink",
"cost": 7568.83,
"location": "Houston",
"make": "Maserati",
"model": "Quattroporte",
"year": 1984
}
]
Creating The Export To Excel Flow
Now we are ready to make the flow to convert the Car Sales Inventory table data to a CSV file. Go to the Action tab and select Power Automate. Then click create a new flow.
Choose the Power Apps button template.
Name the flow PowerAppsToExcel and click Save. We want to use the PowerApps (V2) trigger because it we can manually define inputs and their types. Delete the PowerApps trigger and add PowerApps(V2) in its place.
Create a flow with all of the steps shown below.
Here are a few additional instructions for building the flow corresponding to the numbers on the diagram:
- Click the generate from sample button and copy + paste the the JSON we created in Power Apps earlier.
- A new document library called Export Data must added in SharePoint before selecting it in the create file step.
- The Flow will not create a new file if a CSV with the same name already exists. We can make sure this doesn’t happen by adding a timestamp to the end. Here’s the flow expression you should use.
formatDateTime(utcNow(), 'yyyyMMddhhmmss')
4. We want to encode the CSV file in UTF-8 format so it can handle special characters (accented letters, currency symbols, etc). For example, I had a problem where the Euro symbol (€) was not appearing correctly in my CSV file. To solve the issue, use this code. The 3 character prefix in-front of the body(‘Create_CSV_table) identifies the format to Power Automate as UTF-8.
concat(uriComponentToString('%EF%BB%BF'),body('Create_CSV_table'))
Connect The ‘Export To Excel Flow’ To Power Apps
The salesperson can the download the Car Sales Inventory as a CSV file and view the data in Excel. Insert a new button onto the screen with the text “Download” and place a download icon beside it. Select the button, then open the Power Automate pane from the top-menu and choose the flow we created Power Apps To Excel.
Browse to the OnSelect property of the button, remove any code in there…
…and then use this code instead. It will convert the table data into a JSON, run the flow which returns a CSV file and then downloads the file onto the local drive. From there the salesperson can open the CSV file in Excel.
// convert the table data into a JSON
Set(
varJSONCars,
JSON(
ShowColumns(
'Car Sales Inventory',
"year",
"make",
"model",
"color",
"location",
"cost"
),
JSONFormat.IndentFour
)
);
// run the flow
Set(
varCSVFile,
PowerAppsToExcel.Run(varJSONCars).linkoutput
);
// download the file to Excel
Download(varCSVFile)
Download The CSV File And Open In Excel
We’re done! Go ahead and give the app a try. You can successfully export a table to Excel.
Did You Enjoy This Article? 😺
Subscribe to get new Power Apps & Power Automate articles sent to your inbox each week for FREE
Questions?
If you have any questions or feedback about Power Apps Export To Excel As A CSV File please leave a message in the comments section below. You can post using your email address and are not required to create an account to join the discussion.
Thank you very much, Matthew. That is that I was waiting for implement in my App. I will tried, although my knowledges of JSON and Power Automate are very, very light. If it works me, is it possible to export it Excel directly? because my users aren’t familiar with CSV files…
PD: Sorry, my english isn’t no good.
Duncan,
Excel is possible too. Doing this instead will require changes to your Flow. I will see if I can snap a screenshot of the Flow in the next day or two and share with you.
It would be fantastic! Thanks Matthew.
I love cats too 😉
Duncan,
My apologies for the delay. Here’s a photo of the flow I used to generate an Excel file.
No need to be sorry. I guess you are very busy and I am glad you were able to help me.
I will study the flow to try to understand it and apply it to my application.
I hope to be successful.
Thanks again, Matthew. You are a true Power Apps guru to me 😉
@Matthew Devaney Thank you for your help on this difficult to find capability. I’m wondering if you happen to still have this image if you can break it into two and repost it.
It is too small to read as is; if I enlarge it I can’t get the entire image or scroll down to see all the image and I can’t seem to enlarge it or export so it is readable. I’ve tried everything I can think of!
Thanks so much if this is possible.
Always love your teaching manner!
Cindy,
Can you please tell me which image you are referring to? It would be best if you can tell me the filename (it can be obtained by saving the image to your drive).
Oh My, Matthew! I’m so sorry I did not reply sooner. I’m back to working on this same issue and just now see that you answered me. I’ve got to get this figured out.
I was referring to the image above that you sent to Duncan. I believe this is the file name.
canada.flow_.microsoft.com_manage_environments_Default-f1b8b509-50a4-4a5c-8e48-bf3d3e7c10ed_flows_c3accaf3-80f3-4c62-8395-45c5fb19d788-1626654229.9097-138×300
Thanks ever so much for your always, very helpful, and simply explained content!
So…back at it yet again!
Cindy
Hi Matthew,
Enjoy your examples all simple and easy to follow.
Is it possible to have an export button using flow like your example but using Dataverse Tables that contain lookups.
I’ve noticed it will only export the plan text and numeric columns data.
Thanks
Pat,
That’s a very good question! As you have noticed this method only works for primitive data types (text, number, date, boolean) but it is possible to do. Check out this post on the official Power Apps forums: https://powerusers.microsoft.com/t5/Building-Flows/Create-CSV-from-a-lookup-column/td-p/616663
Hello, thanks for this,
only, particularly with the data (list) being an SPO List, I believe using the in-built “export to excel” function on the SPO List would be easier?
This creates a query, but of course one could then simply copy and paste the content from the query into a “static” Excel table to share it with other people that do not want or need the query/automatic update function or need to add columns etc.
Or am I missing an important aspect here that the flow export handles differently?
Thanks!
Kay
Kay,
Yes, using the Export to Excel feature in SharePoint lists is also a valid solution and can be used if the person knows where to find the list. I like to provide this export option directly in the app so users can remain in PowerApps and not have to go to the SharePoint list if they have access to it and know how to get there. Best practice for apps built on Sharepoint lists is to hide the SP list to prevent direct edits of any items.
Thank you for your question!
Great Explanation! Thanks! Is it possible to change the sort order of the columns in the exported CSV/Excel-File. The Columns always sorted alphabetically…
Karl,
Is the data displayed in the same order as shown on the Power Apps screen? For me, the CSV file was always in the same order. If this is also true for you the order could be controlled with a SORT function in the Items property of the gallery.
My gallery is sorted with this function, but CSV file is sorted alphabetically. I think it could be the way Power Automate generate schema from sample. Maybe it could be edited manually, but I not sure if it will works.
I reply to myself. I be able to sort my columns using personalized columns on “Create a CSV file” action within Power Automate process.
Hi Duncan, Please can you show a code /screenshot of how you sort the columns.
Yes, of course. My Power Automate is in Spanish, but I hope you understand 😉
Though this post has been around for a while, I want to share a couple of things that I learned while creating an export recently.
UpdateContext(
{
locJSONColumns:
“[” &
Mid(
Concat(
colStudentFolders,
“,{
“”Column1″”: “”” & Value1 & “””,
“”Column2″”: “”” & Value2 & “””,
“”Column3″”: “”” & Value3 & “””,
“”Column4″”: “”” & Value4 & “””,
“”Column5″”: “”” & Value5 & “””,
}”
)
, 2
)
& “]”
}
);
// Open the Excel file
Download(
//Run the flow
ExporttoExcel.Run(locJSONStudentFolders).filelink
)
Hope this helps someone!
Francisco,
This is pretty great advice. I may need to adjust my tutorial to incorporate the Power Automate json() function instead of the Power Apps ParseJson() function
hey Francisco, do you happen to have a link to the Reza Dorrani resouce?
Hi can you share a link to the Reza resource?
Thank you Matthew, really good job, im need to implement this in my app, but in the line: “Set(
varCSVFile,
PowerAppsToExcel.Run(varCars).linkoutput
);“, what is the value of this varCars and when this variable was set?
Alex,
It was a typo. The variable name should be varJSONCars and is created in the preceding line of code.
ok thanks, have a way to export the data after the table has been filtered?
Hi again, Matthew.
I have beem able to export filtered lists on my app to CSV. Most of fields in these lists have a choice value, then in CSV file apears like “value: choice”. Is there any way to show only the choice?
Thank you.
Sorry Matthew for this question. Using custom columns in the “create CSV file” action, allows you to display only values.
Hi Matthew, thanks for the great article. There were a few minor things that caught me out:
Thanks again 🙂
Harjit,
Thank you for the feedback. I have updated the blog to incorporate your suggestions 🙂
Heya Matthew, thank you so much for this article, it really helped a lot.
I used custom columns now to specify what output exactly I want as some columns are objects and it exported a string like “Value: “ABC””.
I also tried the XLS export, this creates a file as I want, but then the App gets a timeout from the flow before its ready to download, so I keep using the CSV export which works OK.
However, I would like to change the CSV separator from Comma to Semicolon as one of the columns in my list includes Commas. Is there a way to change this? Or maybe a workaround when creating the CSV Table?
Thanks,
Dave
Dave,
I have an idea on how to incorporate semi-colons. Here’s the general strategy:
1. Temporarily replace all of the commas in your fields to an unused character using some flow action.
2. Run the convert to CSV table action
3. Substitute the commas with semi colons using a flow expression
4. Substitute the ~ with commas using a flow expression.
Hope this basic outline helps
Wow this is great. I did not think that replacing the inputs would be possible within the flow. Thanks for pointing me in the right direction, will check this now and will share my results here 🙂
Have a great day.
Thank you Matthew for this. Issue which we are facing with this is, special characters like € doesnot get displayed correctly in csv file.User can change the csv file unicode setting manually but how tsymbols like € can be displayed automatically without user’s manual intervention?
Shubh,
You posed a really good question that required research on my part! Sorry it took so long to get back to you 🙁
There seems to be a limitation to exporting CSVs through flow in this manner. We need the file to be UTF-8 in order to read characters like € but flow uses some different format. I have couple of thoughts: the first is you could generate a dynamic excel file instead of a CSV. There is a screenshot of how to do it earlier in this post. I might need to make a new post on it because of what you found. Don’t worry, creating an Excel file is still FREE under the seeded Power Automate plan.
Also, I wonder if there is an API that can do it. Might be worth some research but this would be a premium option.
I found the solution to this problem. Tested it and it works: https://powerusers.microsoft.com/t5/Building-Flows/Create-a-csv-file-that-uses-UTF-8-character-encoding/td-p/559864
The solution is to add 3 BOM characters in front of the .csv file content before saving it.
concat(uriComponentToString(‘%EF%BB%BF’),body(‘Create_CSV_table’))
Diego,
This is brilliant. I am so thankful for you sharing this information with me. Wow! I will update my update my article in a few days to include it.
Also, I accepted the forums post as the solution. No one else is seeing this because the original poster never bothered to mark a solution 😮
Glad I could help, as you have helped me a lot with your articles!
Hello Mr Delaney,
Its Awesome that I have a reference from you,
Firstly, Thank you very for knowledge,
i follow your code, and it works until file on sharepoint created, but i was got an error with download. the picture as below,
I appreciated for your help.
Thank You,
Dienuk,
Can you please share the error message that is associated with the red underlined code? This is the best way to tell what’s gone wrong.
Matthew,
The problem is solving now, I just forgot to enter link share point site before Path on compose flow. without link site its make a different.
Thank you very much,
Nice article, I have replicated this in my app. Just a quick question… My number column dataype (Sharepointlist) was set to have decimal values from the SPList side and it shows there, it even shows well in the powerapps gallery. But when I did this your process, it is removing the .00 i.e 3000.00 to be this 3000. Please how do I rectify? from the JSON I have set TYPE as number all to no avail.
Utoro,
Unfortunately, a number type with .00 in the decimal place will always truncate to remove it. If you need a formatted number it might be necessary to output it into the CSV as text… though this might not be satisfactory depending on your use case.
Hi Matthew, thanks for sharing this method, I have a business needs where users would like to filter the data before exporting. Would this method work with this requirement? Or will it export the entire sharepoint list?
Haley,
My tutorial will download the entire SharePoint list but you can modify it to download a filtered table instead.
For example, lets say you have a dropdown to let the user filter by “year”. You could use this code to create a JSON only having data for a selected year.
// convert the table data into a JSON
Set(
varJSONCars,
JSON(
ShowColumns(
// code to filter data
Filter(
‘Car Sales Inventory’,
IsBlank(drp_year.Selected) Or year=drp_year.Selected.Value
),
“year”,
“make”,
“model”,
“color”,
“location”,
“cost”
),
JSONFormat.IndentFour
)
);
Hi Matthew,
Thanks for this article. This will be a lifesaver for me. The flow saved without error Unfortunately, I ran into the following problems when updating the OnSelect property of the button in PowerApps. kindly review and assist


Thanks for the article Matthew,
I ran into trouble while replicating this in an app.
Here are the error lines. errors description are italicized while errors are bolded.
// run the flow
Set(
varCSVFile,
PowerAppsbutton.Run(varJSONSIUDB).linkoutput //(error: Invalid use of ‘.’)
);
// download the file to Excel
Download(VarCSVFile) //(error: Invalid argument type (Error). Expecting a Hyperlink value instead.)
George,
The linkoutput must be a valid web address starting the prefix ‘https://’. Can you please share what the text string linkoutput looks like in Power Apps? Put it in a variable and display it somewhere on the screen to check it.
Thanks for the feedback Matthew,
I have made some changes to the OnSelect action.
please be patient with my annoying questions and comments:
This is my updated OnSelect Button Action
I updated the OnSelect action to the below and will only run and execute successfully if I remove the below bolded fields/columns which are not text/string but choice/date:
PowerAppsbutton.Run(// convert the table data into a JSON
Set(
varJSONSIUDB,
JSON(
ShowColumns(
‘SIU DATABASE’,
“Title”,
“First_x0020_Name”,
“Last_x0020_Name”,
“Agency”,
“Broad_x0020_Classification”,
“Suivi1”,
“Section_x0020_def”
),
JSONFormat.IndentFour
)
);
// run the flow
Set(
varCSVFile,
PowerAppsbutton.Run(varJSONSIUDB).linkoutput
);
// download the file to Excel
Download(varCSVFile)
)
I am not sure how to include non text fields which will include choice and date columns. If include the choice columns and set the type to “string” I get an error that system expected a string got an object and if I change the type to “object”, the system flow fails again and give an inverse response, it expected an object and got a string instead. below are the schemas in my flow:
option 1.
+++++++++++++++
{
“type”: “array”,
“items”: {
“type”: “object”,
“properties”: {
“Title”: {
“type”: “string”
},
“First_x0020_Name”: {
“type”: “string”
},
“Last_x0020_Name”: {
“type”: “string”
},
“Agency”: {
“type”: “string”
},
“Broad_x0020_Classification”: {
“type”: “string”
},
“Suivi1”: {
“type”: “string”
},
“Section_x0020_def”: {
“type”: “string”
}
}
}
}
option 2.
++++++++++++++++++++++++++
{
“type”: “array”,
“items”: {
“type”: “object”,
“properties”: {
“Title”: {
“type”: “string”
},
“First_x0020_Name”: {
“type”: “string”
},
“Last_x0020_Name”: {
“type”: “string”
},
“Agency”: {
“type”: “object”
},
“Broad_x0020_Classification”: {
“type”: “object”
},
“Suivi1”: {
“type”: “object”
},
“Section_x0020_def”: {
“type”: “object”
}
}
}
}
Lastly, when I omit these trouble fields and maintain only the first three text fields everything execute successfully, I get the downloaded file but its output is limited to 500 rows whereby the list contains more than 3,000 rows of items. Is there a way to extend this limit?
Apologies, I know this is a lot. Kindly review and let me know where you can help.
Thanks,
George
George,
Choice-type columns have an ID and a Value. You would need to extract the Value and pass that into the flow.
For the date-type column, consider trying pass it in like this: Text(your_date_here,”dd/mm/yyyy”)
Not sure about the final question of 500+ records though… was not aware of the flow limits for returning records.
Hello Matthew
Thanks for this article
Please suggest how to extract value from choice type column and pass that into the flow. Because in CSV file it shows as “value: choice”.
Priya,
Sorry, but this method only works with primitive data types: text, number, date, yes/no
One possible solution/workaround: Create a calculated SharePoint column.
For example, if your choice column is named “Status”, create a new calculated single line of text column, named “CalStatus”, and input the following formula: =[Status]. Then, update the flow and OnSelect programming to look for CalStatus in lieu of the original Status column.
Hy Mr Devaney.
Congrats for the blog’s content, it is amazing!
A simple situation, but not easy to find out how to solve. I have an Excel file (One Drive Business placed), with one table (Table1) that I use to create another table (Table2), which is visible in the app. The question is: how to send by email the generated Table2? The problem is how to refer Table2 in the email settings file as attachment. Is it possible, considering I am using One Drive Business? The email is always sent, ok. But the attachment, no way…
See attached where is the doubt.
Thank you for your time on it.
Best.
Ricardo Salmazi
Ricardo,
I think this 5 min video by Druvin Shah will explain how to attach the files more quickly than I can write a detailed response… enjoy 🙂
https://www.youtube.com/watch?v=5kJ7RFIeaOo
Yeah… Perfect! I didn’t do it yet, but the video shows exctely what I am trying to do. Thank you very much for the tip. And congrats once more for the knowledge and for tsharing it. By the way, Penelope is my 21 years old cat. She use to stay with me every day, over the table, trying to get my hand of the mouse…rsrsrs. She is sending her regards too.
Cheers!
Matthew, this article was by far the most helpful PowerApps resource I have found so far. I never would have been able to figure this out by myself. Thank you so much!
Sam,
You’re welcome! That’s why I write this stuff 🙂
Hi Mathew,
Thank you very much for this tutorial. I am have one a kind issue 🙁 For my scenario, i am trying to take the csv output of the Gallery the source of which is a Collection connected to SP. (I needed to get a collection since the number of line items in my SP is more). However I am getting the below JSON error.
I did try a bit of research in google. and found the below reasoning,
Upon exploring on the reason behind this error understand that, JSON wont be able to work with Record Columns (technically choice columns or people picker). Eliminating these columns in the flow configuration, the excel export is working as intended. However, the requirement is to export all the values (including the choice column value selected).
I did try to create another column in SP list, that will be get auto populated once the values in the choice column is selected. This too isn’t working, since it says Power Automate cannot work with calculated columns.
Kindly help me find a solution. I am sitting on this for the past 1 week 🙁
Hi Matthew, Thank you for the detailed description on this topic.
While implementing one of my requirements, observed the columns exported in csv file are always in alphabetical order (Column names starting with A, B, C…).
However, I want to have them as per user convince. Display column B first, then column F then column A, likewise, in shuffle order.
Could you please help on this part?
Same problem here
I found the solution, chech this out:
https://powerusers.microsoft.com/t5/Building-Flows/How-to-change-the-order-of-the-columns-when-creating-a-CSV-table/m-p/1253958#M143406
Hi Mattew. Hope you’re fine. Just to ask whether you have any article about how to refer to an active screen text box in the Odata filter query. Yeah, I’m trying to use just some of records of an Excel file, but dynamically. Maybe creating a variable, but still I don’t know how to refer to it in the Odata field.
Thanks, Mattew!
This is a great step-by-step but i have two questions/issues. 1) when creating the flow, Power Apps Button wasnt an option. But i was able to use Create From Blank option which seemed to work fine.
2) Although the steps were copied (each step looks identical to the images) with two exceptions of using my own sql server datasource in the datatable and changing the field names as needed, I get the error:
“incompatible type. we can’t evaluate your formula because the context variable types are incompatible with the types of values in other places in your app” This happens on the line:
Set(
varCSVFile,
PowerAppsToExcel.Run(varJSONCars).linkoutput
);