Find everything you need to get certified on Fabric—skills challenges, live sessions, exam prep, role guidance, and more. Get started
I'm looking to ensure my Power BI report pulls the latest data from a SharePoint file without having to overwrite the current sharepoint file with the latest data.
Each day a new file is received and saved into the same SharePoint folder with the name (________YYYYMMDDhhmmss).xlsx. This has the exact same layout (columns, tabs, etc) as the previous file, however with the latest data.
Rather than having to copy and paste into the current file, overwrite the current file, or change the load data query each day, I'm hoping there is a way for Power BI to look in the same SharePoint folder and use the latest file.
I am new to Power BI so would greatly appreciate any simple instructions, clearly explained. Thanks community 🙂
Solved! Go to Solution.
Steps would be like this:
Thanks Jeff. And to confirm, would this have the effect that each morning Power BI will pull from the latest/top report in the folder?
Yes, it should. Each refresh will pull the max dated file.
Steps would be like this:
I have looked online and i still don't get how i can edit my query to make this update with a new file each day the date changes
where the next day would be ALL_SOL_2024_07_18.csv, to ALL_SOL_2024_07_19.csv
let
Source = SharePoint.Files("https://mydnb.sharepoint.com/sites/teams/na_delivery/", [ApiVersion = 15]),
#"Filtered Rows" = Table.SelectRows(Source, let latest = List.Max(Source[Date created]) in each [Date created] = latest),
#"ALL_SOL_2024_07_18 csv_https://mydnb sharepoint com/sites/teams/na_delivery/606 Fulfillment Template/UPLOAD/RRF_REPORTS/" = #"Filtered Rows"{[Name="ALL_SOL_2024_07_18.csv",#"Folder Path"="https://mydnb.sharepoint.com/sites/teams/na_delivery/606 Fulfillment Template/UPLOAD/RRF_REPORTS/"]}[Content],
#"Imported CSV" = Csv.Document(#"ALL_SOL_2024_07_18 csv_https://mydnb sharepoint com/sites/teams/na_delivery/606 Fulfillment Template/UPLOAD/RRF_REPORTS/",[Delimiter=",", Columns=14, Encoding=1252, QuoteStyle=QuoteStyle.None]),
#"Promoted Headers" = Table.PromoteHeaders(#"Imported CSV", [PromoteAllScalars=true]),
#"Changed Type" = Table.TransformColumnTypes(#"Promoted Headers",{{"SOL - ID", type text}, {"SOL - Line Sequence", Int64.Type}, {"SOL - POB", Int64.Type}, {"SOL - End Date", type date}, {"SOL - Start Date", type date}, {"SOL - Qty Ordered", Int64.Type}, {"SOL - Product Name", type text}, {"SOL - Ratable Indicator", Int64.Type}, {"SOL - Description", type text}, {"SOL - OA Nbr", Int64.Type}, {"SOL - Manual Subsequent Indicator", Int64.Type}, {"SOL - Unit Type", type text}, {"SOL - Source DID", type text}, {"SOL_is_cancelled", type text}})
in
#"Changed Type"
Won't clicking on "Binary" result in a series of steps where the File Name is hard-coded?
Good point. The default generated Power Query will--but you can edit it to use index-based identifiers instead of named ones.
Thank you for your confirmation!
May I also ask how to revise the code to use index-based identifiers in the following auto-generated steps?
= #"Filtered Rows"{[Name="Products.xlsx",#"Folder Path"="https://sharepoint.com/sites/References/"]}[Content]
= Excel.Workbook(#"Products xlsx_https://sharepoint.com/sites/References/")
The row filtering criteria is embedded in the #"Filter Rows" step. You'll need to move this logic into step(s) before #"Filtered Rows", filtering to just one row, and then selecting it.
Something like this:
let
Source = SharePoint.Files("https://sharepoint.com/", [ApiVersion = 15]),
#"Filtered Rows" = Table.SelectRows(Source, each [Name] = "Filename" and [Folder Path] = "URL"),
Content = #"Filtered Rows"{0}[Content],
#"Imported Excel Workbook" = Excel.Workbook(Content)
in
#"Imported Excel Workbook"
this works! thank you so much!
Check out the September 2024 Power BI update to learn about new features.
Learn from experts, get hands-on experience, and win awesome prizes.
User | Count |
---|---|
116 | |
101 | |
87 | |
35 | |
35 |
User | Count |
---|---|
152 | |
99 | |
83 | |
63 | |
54 |