Power BI is turning 10, and we’re marking the occasion with a special community challenge. Use your creativity to tell a story, uncover trends, or highlight something unexpected.
Get startedJoin us for an expert-led overview of the tools and concepts you'll need to become a Certified Power BI Data Analyst and pass exam PL-300. Register now.
Hi,
until now I manually managed to extract data from 2 Excel files located in a Sharepoint folder.
One file was related to 2020 data and the other to 2021 data.
Each Excel file contains 15 tabs with the same name and data structure. As displayed below
At the end of all transformations this is the result
Now, I would like to automate my manual process for the years to come.
In other words, my goal would be to limit the update process of my dataset to 2 actions:
1. Copy the new data file into the Sharepoint folder
2. Refresh the Power BI dataset
And here is my challenge:
I just know how to read and filter the proper files from the Sharepoint folder. But after that, I have 2 problem to address:
a. how to iterate throughout all the Excel file Spreadsheets to read all data tables
b. how to unpivot my tables, when I have multiple years listed that should become my new date dimension, like in the example below
Situation before unpivoting (first spreadsheet of the 2 Excel files):
Result expected:
Thank you for any advise.
m
Solved! Go to Solution.
Thank you @wdx223_Daniel ,
it does work, but the result is not exactly what I expected.
I adapted your code in this way:
let
Source = SharePoint.Files("my Sharepoint path", [ApiVersion = 15]),
#"Filtered Rows" = Table.SelectRows(Source, each Text.StartsWith([Name], "my text filter")),
custom1=Table.Combine(List.TransformMany(#"Filtered Rows"[Content],each Excel.Workbook(_)[Data],(x,y)=>Table.UnpivotOtherColumns(y,{"Column1","Column2","Column3"},"End of Mounth","Value")))
in
custom1
and this is the result
At the end I solved my need with the following solution
let
Source = SharePoint.Files("my Sharepoint url", [ApiVersion = 15]),
#"Filtered Rows" = Table.SelectRows(Source, each Text.StartsWith([Name], "my text filter")),
WorkbookList = List.Transform(#"Filtered Rows"[Content], each Excel.Workbook(_)[Data]),
SpreadsheetList = List.Combine(WorkbookList),
TransformTable = (SpreadsheetList as list) as list =>
let
TransformedTable = List.Transform(
SpreadsheetList, each
Table.UnpivotOtherColumns(
Table.PromoteHeaders(_, [PromoteAllScalars=true]),
{"Col1", "Col2", "Col3"},
"Attribute", "Value"))
in
TransformedTable,
SpreadsheetTable = Table.Combine(TransformTable(SpreadsheetList))
in
SpreadsheetTable
Thank you again @wdx223_Daniel for your answer, because helped me to understand better iterations in M, you deserve a Kudos!
m
let
source=Folder.Files("your folder path"),
custom1=Table.Combine(List.TransformMany(source[Content],each Excel.Workbook(_)[Data],(x,y)=>Table.UnpivotOtherColumns(y,{the column name list which you do not want to unpivot},"End of Month","Value")))
in custom1
Thank you @wdx223_Daniel ,
it does work, but the result is not exactly what I expected.
I adapted your code in this way:
let
Source = SharePoint.Files("my Sharepoint path", [ApiVersion = 15]),
#"Filtered Rows" = Table.SelectRows(Source, each Text.StartsWith([Name], "my text filter")),
custom1=Table.Combine(List.TransformMany(#"Filtered Rows"[Content],each Excel.Workbook(_)[Data],(x,y)=>Table.UnpivotOtherColumns(y,{"Column1","Column2","Column3"},"End of Mounth","Value")))
in
custom1
and this is the result
At the end I solved my need with the following solution
let
Source = SharePoint.Files("my Sharepoint url", [ApiVersion = 15]),
#"Filtered Rows" = Table.SelectRows(Source, each Text.StartsWith([Name], "my text filter")),
WorkbookList = List.Transform(#"Filtered Rows"[Content], each Excel.Workbook(_)[Data]),
SpreadsheetList = List.Combine(WorkbookList),
TransformTable = (SpreadsheetList as list) as list =>
let
TransformedTable = List.Transform(
SpreadsheetList, each
Table.UnpivotOtherColumns(
Table.PromoteHeaders(_, [PromoteAllScalars=true]),
{"Col1", "Col2", "Col3"},
"Attribute", "Value"))
in
TransformedTable,
SpreadsheetTable = Table.Combine(TransformTable(SpreadsheetList))
in
SpreadsheetTable
Thank you again @wdx223_Daniel for your answer, because helped me to understand better iterations in M, you deserve a Kudos!
m
This is your chance to engage directly with the engineering team behind Fabric and Power BI. Share your experiences and shape the future.
Check out the June 2025 Power BI update to learn about new features.
User | Count |
---|---|
15 | |
11 | |
8 | |
8 | |
7 |
User | Count |
---|---|
14 | |
13 | |
9 | |
7 | |
6 |