Advance your Data & AI career with 50 days of live learning, dataviz contests, hands-on challenges, study groups & certifications and more!
Get registeredJoin us at FabCon Atlanta from March 16 - 20, 2026, for the ultimate Fabric, Power BI, AI and SQL community-led event. Save $200 with code FABCOMM. Register now.
Hello,
I posted this some days ago:
https://community.powerbi.com/t5/Desktop/Grouping-by-and-separating-by-year/m-p/2252436#M819467
The answer given in the post is correct, but the fact that it is a virtual table created with measures gives me alot of problems when I try to create dashboards with new columns. In my understanding it would be better to have a table created in Power Query for my specifics needs.
The sample data is the same as in the post, with the difference that I no longer need exact matches in the grouping of both years, this means that the desired output is the following:
City | State | Customer Type | Revenue agg 2021 | Quantity agg 2021 | Revenue agg 2020 | Quantity agg 2020 |
Melbourne | VIC | Home Office | 49.54 | 82 | 1.87 | 29 |
Sydney | NSW | Corporate | 126.38 | 175 | 2.69 | 22 |
Sydney | NSW | Consumer | 0.59 | 33 | 1.2 | 17 |
Sydney | NSW | Small Business | 36.19 | 8 | 2.74 | 70 |
Melbourne | VIC | Corporate | 3.61 | 106 | null | null |
Sydney | NSW | Home Office | 4.92 | 16 | null | null |
I think the way to go is:
Now my questions are:
Maybe there is an easier way of doing this but I'm not sure.
Any suggestion would be deeply appreciated,
Thanks.
Solved! Go to Solution.
(I will delete my previous answer, as this one is much improved especially with large database)
Try with
Also, omitting the re-sorting operation at the end may also speed things up as that has to re-read the entire table.
let
Source = Excel.CurrentWorkbook(){[Name="Table9"]}[Content],
#"Changed Type" = Table.TransformColumnTypes(Source,{
{"Order No", type text}, {"Order Year", Int64.Type}, {"City", type text},
{"State", type text}, {"Customer Type", type text}, {"Order Priority", type text},
{"Product Category", type text}, {"Profit Margin", type number}, {"Order Quantity", Int64.Type}}),
//filter to include only current and previous years
#"Filtered Rows" = Table.SelectRows(#"Changed Type", each
[Order Year] = Date.Year(Date.From(DateTime.LocalNow()))
or [Order Year] = -1 + Date.Year(Date.From(DateTime.LocalNow()))
),
//Group and sum
#"Grouped Rows" = Table.Group(#"Filtered Rows", {"Order Year","City", "State", "Customer Type"}, {
{"Revenue", each List.Sum([Profit Margin]),Currency.Type},
{"Quantity", each List.Sum([Order Quantity]), Int64.Type}
}),
#"Unpivoted Columns" = Table.UnpivotOtherColumns(#"Grouped Rows", {"Order Year", "City", "State", "Customer Type"}, "Attribute", "Value"),
#"Merged Columns" = Table.CombineColumns(Table.TransformColumnTypes(#"Unpivoted Columns", {{"Order Year", type text}}, "en-US"),{"Order Year", "Attribute"},Combiner.CombineTextByDelimiter(" ", QuoteStyle.None),"Merged"),
#"Pivoted Column" = Table.Pivot(#"Merged Columns", List.Distinct(#"Merged Columns"[Merged]), "Merged", "Value")
in
#"Pivoted Column"
Message deleted by author
Hi @ronrsnfld ,
The answer that you gave me is exactly what I was looking for, the problem is when I try to replicate the code in my original data (with only a million rows). It uses 90% of my RAM and it hasn't finished yet after an hour and a half. Given that the whole data that I will be using (more than 10 million rows) I'm not sure how to proceed.
(I will delete my previous answer, as this one is much improved especially with large database)
Try with
Also, omitting the re-sorting operation at the end may also speed things up as that has to re-read the entire table.
let
Source = Excel.CurrentWorkbook(){[Name="Table9"]}[Content],
#"Changed Type" = Table.TransformColumnTypes(Source,{
{"Order No", type text}, {"Order Year", Int64.Type}, {"City", type text},
{"State", type text}, {"Customer Type", type text}, {"Order Priority", type text},
{"Product Category", type text}, {"Profit Margin", type number}, {"Order Quantity", Int64.Type}}),
//filter to include only current and previous years
#"Filtered Rows" = Table.SelectRows(#"Changed Type", each
[Order Year] = Date.Year(Date.From(DateTime.LocalNow()))
or [Order Year] = -1 + Date.Year(Date.From(DateTime.LocalNow()))
),
//Group and sum
#"Grouped Rows" = Table.Group(#"Filtered Rows", {"Order Year","City", "State", "Customer Type"}, {
{"Revenue", each List.Sum([Profit Margin]),Currency.Type},
{"Quantity", each List.Sum([Order Quantity]), Int64.Type}
}),
#"Unpivoted Columns" = Table.UnpivotOtherColumns(#"Grouped Rows", {"Order Year", "City", "State", "Customer Type"}, "Attribute", "Value"),
#"Merged Columns" = Table.CombineColumns(Table.TransformColumnTypes(#"Unpivoted Columns", {{"Order Year", type text}}, "en-US"),{"Order Year", "Attribute"},Combiner.CombineTextByDelimiter(" ", QuoteStyle.None),"Merged"),
#"Pivoted Column" = Table.Pivot(#"Merged Columns", List.Distinct(#"Merged Columns"[Merged]), "Merged", "Value")
in
#"Pivoted Column"
Hi @Anonymous
The desired output can be a matrix? Or you have specific request of the column names, order, etc?
Hi @Vera_33,
The desired output should be like the following image:
let
Source = Excel.CurrentWorkbook(){[Name="Table1"]}[Content],
Custom1 = Table.Group(
Source,
{"City","State","Customer Type"},
List.TransformMany(
List.Sort(List.Distinct(Source[Order Year]),1),
each {"Revenue","Qantity"},
(x,y)=>{
y&" agg "&Text.From(x),
each List.Sum(
Table.Column(
Table.SelectRows(
_,
(s)=>s[Order Year]=x
),
if y="Revenue"
then "Profit Margin"
else "Order Quantity"
)
)
}
)
)
in
Custom1
Join the Fabric FabCon Global Hackathon—running virtually through Nov 3. Open to all skill levels. $10,000 in prizes!
Check out the October 2025 Power BI update to learn about new features.