Power Apps Export To Excel As A CSV File

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:

YearMakeModelColorLocationCost
2000HondaAccordOrangeHouston15,242.74
1998OldsmobileAuroraOrangeAustin14,691.91
1984MaseratiQuattroportePinkHouston7,568.83
2011ChevroletMalibuTurquoiseFort Worth22,711.39
2006Mercedes-BenzG-ClassCrimsonFort Worth13,949.48
1985FordLaserGreenDallas34,159.31
2009KiaSpectraFusciaDallas29,023.15
1996DodgeRam Van 3500YellowSan Antonio24,883
1985BuickCenturyOrangeFort Worth33,778.10
2009Mercedes-BenzS-ClassBlueFort Worth27,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:

  1. Click the generate from sample button and copy + paste the the JSON we created in Power Apps earlier.
  2. A new document library called Export Data must added in SharePoint before selecting it in the create file step.
  3. 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.




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.

Matthew Devaney

Subscribe
Notify of
guest

117 Comments
Oldest
Newest
Inline Feedbacks
View all comments
Duncan
Duncan
3 years ago

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
Duncan
3 years ago

It would be fantastic! Thanks Matthew.

I love cats too 😉

Last edited 3 years ago by Duncan
Duncan
Duncan
3 years ago

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 😉

Last edited 3 years ago by Duncan
Cindy
Cindy
2 years ago

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
Cindy
2 years ago

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

Pat
Pat
3 years ago

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

Kay
Kay
3 years ago

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

Karl Gerd Schneider
Karl Gerd Schneider
3 years ago

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…

Last edited 3 years ago by Karl Gerd Schneider
Duncan
Duncan
3 years ago

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.

Duncan
Duncan
3 years ago
Reply to  Duncan

I reply to myself. I be able to sort my columns using personalized columns on “Create a CSV file” action within Power Automate process.

Karthi
Karthi
3 years ago
Reply to  Duncan

Hi Duncan, Please can you show a code /screenshot of how you sort the columns.

Duncan
Duncan
3 years ago
Reply to  Karthi

Yes, of course. My Power Automate is in Spanish, but I hope you understand 😉

Screenshot_20210715_172016.png
Last edited 3 years ago by Duncan
Francisco
Francisco
10 months ago
Reply to  Duncan

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.

  1. Standardization – This approach locks me into creating a flow for every export and I wanted one flow for all exports. I learned from Reza Dorrani to skip the “Parse JSON” step and use json(triggerBody()[‘text’]) as the input (From:) to “Create table CSV”. With this, I can use the same flow for all my exports.
  2. Column order – While it is true that “Create table CSV” allows for a custom order of columns in the CSV, it also locked me into a flow for each export. I read that when feeding an array to the JSON function, it alphabetizes the properties, if fed a string, it does not. Do not know enough JSON to know if that is true but it made sense. So, from April Dunnam, I learned to create my own JSON string and avoid using the function in Power Apps. Like this:

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!

Sukh
Sukh
2 months ago
Reply to  Francisco

hey Francisco, do you happen to have a link to the Reza Dorrani resouce?

Last edited 2 months ago by Sukh
Sukh
Sukh
2 months ago
Reply to  Francisco

Hi can you share a link to the Reza resource?

Alexandre
Alexandre
3 years ago

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?

Alexandre
Alexandre
3 years ago

ok thanks, have a way to export the data after the table has been filtered?

Duncan
Duncan
3 years ago

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.

Duncan
Duncan
3 years ago
Reply to  Duncan

Sorry Matthew for this question. Using custom columns in the “create CSV file” action, allows you to display only values.

Harjit Samra
3 years ago

Hi Matthew, thanks for the great article. There were a few minor things that caught me out:

  1. The document library ‘Exported Data’ has to be created in SharePoint
  2. The file name in ‘Create File’ in Power Automate should have .csv appended to it.

Thanks again 🙂

Dave
Dave
3 years ago

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
Dave
3 years ago

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.

Shubh Majumdar
Shubh Majumdar
3 years ago

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?

Diego
Diego
2 years ago

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
Diego
2 years ago

Glad I could help, as you have helped me a lot with your articles!

Dieunk
3 years ago

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,

downloadIssue.png
Dian Hudayah R
3 years ago

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,

Utoro Princewill
Utoro Princewill
3 years ago

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.

Haley Duong
Haley Duong
3 years ago

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?

George
George
2 years ago

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




George
George
2 years ago

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.)

pic1.png
George
George
2 years ago

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

flow.PNG
Priya
Priya
2 years ago

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”.

Mary
Mary
8 months ago

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.

Ricardo
2 years ago

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

Bug.png
Ricardo
2 years ago

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!

Sam
Sam
2 years ago

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!

Ashwini Bharathi
Ashwini Bharathi
2 years ago

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 🙁

json error.JPG
Ayushi
Ayushi
2 years ago

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?

Gustavo
Gustavo
2 years ago
Reply to  Ayushi

Same problem here

Ricardo
2 years ago

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!

Rich
Rich
2 years ago

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
);