- Subscribe to RSS Feed
- Mark Topic as New
- Mark Topic as Read
- Float this Topic for Current User
- Bookmark
- Subscribe
- Printer Friendly Page
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Power Query: M - is it possible to use List.Sum on a set of columns retrieved via List.Difference?
Solved! Go to Solution.
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
So far, you're only dealing with the table's column names and not with the actual values of each row/record. So you have to adjust your formula like so:
let Source = Table.FromRows(Json.Document(Binary.Decompress(Binary.FromText("i45WCjQyNTAxVtJRcnFxAZIgVl5pTg6QMjMHEgZKsToQRaamQK6rqytCgSFIsbkhiGWhFBsLAA==", BinaryEncoding.Base64), Compression.Deflate)), let _t = ((type text) meta [Serialized.Text = true]) in type table [ID = _t, Name = _t, Column1 = _t, Column2 = _t, Column3 = _t, Column4 = _t]), #"Changed Type" = Table.TransformColumnTypes(Source,{{"ID", type text}, {"Name", type text}, {"Column1", Int64.Type}, {"Column2", Int64.Type}, {"Column3", Int64.Type}, {"Column4", Int64.Type}}), #"Added Custom" = Table.AddColumn(#"Changed Type", "Custom", each List.Sum(Record.FieldValues(Record.SelectFields(_, List.Difference(Table.ColumnNames(Source), {"ID", "Name"}))))) in #"Added Custom"
Imke Feldmann (The BIccountant)
If you liked my solution, please give it a thumbs up. And if I did answer your question, please mark this post as a solution. Thanks!
How to integrate M-code into your solution -- How to get your questions answered quickly -- How to provide sample data -- Check out more PBI- learning resources here -- Performance Tipps for M-queries
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Hi There,
I am trying to replicate a simple Excel Step in Power Query, but getting into meny errors
Have a table wti the Following column: "P", "D", "S","N"
I want to add a new colums
Custom= Sum( P- (D+S) - N)
I have been trying wit List.Sum but I can't find the right sysntax. Hope you can help. I am not very confident with the Query Editor
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
I don't think you need List.Sum at all.
Your fomula should just be [P]-([D]+[S]) - [N]
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Thank you Karimm, you are 100% right! Thanks a lot
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Thank you so much Imke!
You are perfeclty right and that perfectly works.
Again, here are my warmest thanks!
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Hi!
Thank you so much for your kindness.
All that I can share is this example with dummy data, but it exactly represents the issue.
Starting from a situation like the following (let it be our "Source"):
ID Name Column 1 Column 2 Column 3 Column 4
Q25019 XXX 46 109 11 3
Q25024 YYY 59 333 55 92
Q25030 ZZZ 27 208 29 108
Q25032 AAA 6 62 10 8
Q25039 BBB 3 136 null 2
Q25040 CCC 2 26 6 null
Q25043 DDD 3 67 null null
Q25055 EEE 13 71 18 2
I replaced the null values with the first formula, above, in order to avoid to hard-code the field labels (they may change):
ReplacedNull = Table.ReplaceValue(Source, null, 0, Replacer.ReplaceValue,
List.Difference(Table.ColumnNames(Source), {"ID", "Name"}))
And it works. Please, notice how I had to reference the previous step twice (Source).
- The first time as it normally requires;
- The second time to feed it with the same data-set for "Table.ColumnNames", in order to wrap everything into List.Difference...
Now, I have:
ID Name Column 1 Column 2 Column 3 Column 4
Q25019 XXX 46 109 11 3
Q25024 YYY 59 333 55 92
Q25030 ZZZ 27 208 29 108
Q25032 AAA 6 62 10 8
Q25039 BBB 3 136 0 2
Q25040 CCC 2 26 6 0
Q25043 DDD 3 67 0 0
Q25055 EEE 13 71 18 2
But... when I try to sum the Columns (1, 2, 3, 4) up with this:
InsertedSum = Table.AddColumn(ReplacedNull, "Total",
each List.Sum(List.Difference(Table.ColumnNames(ReplacedNull), {"ID", "Name"})), type number)
...it does not work!
Of course, I am just asking for a simple sum, which can be achieved with:
InsertedSum = Table.AddColumn(ReplacedNull, "Total",
each List.Sum({[Column1], [Column2], [Column3], [Column4]}), type number)
but... what if I do really need to avoid hard-coding these columns?
I am also attaching a screenshot, shold that result unreadable...
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
So far, you're only dealing with the table's column names and not with the actual values of each row/record. So you have to adjust your formula like so:
let Source = Table.FromRows(Json.Document(Binary.Decompress(Binary.FromText("i45WCjQyNTAxVtJRcnFxAZIgVl5pTg6QMjMHEgZKsToQRaamQK6rqytCgSFIsbkhiGWhFBsLAA==", BinaryEncoding.Base64), Compression.Deflate)), let _t = ((type text) meta [Serialized.Text = true]) in type table [ID = _t, Name = _t, Column1 = _t, Column2 = _t, Column3 = _t, Column4 = _t]), #"Changed Type" = Table.TransformColumnTypes(Source,{{"ID", type text}, {"Name", type text}, {"Column1", Int64.Type}, {"Column2", Int64.Type}, {"Column3", Int64.Type}, {"Column4", Int64.Type}}), #"Added Custom" = Table.AddColumn(#"Changed Type", "Custom", each List.Sum(Record.FieldValues(Record.SelectFields(_, List.Difference(Table.ColumnNames(Source), {"ID", "Name"}))))) in #"Added Custom"
Imke Feldmann (The BIccountant)
If you liked my solution, please give it a thumbs up. And if I did answer your question, please mark this post as a solution. Thanks!
How to integrate M-code into your solution -- How to get your questions answered quickly -- How to provide sample data -- Check out more PBI- learning resources here -- Performance Tipps for M-queries
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Hi @ImkeF ,
Thank you for your answer and continuous help to the community.
I've used the following method to sum up a list of columns whose names are stored in a variable named EstimateFieldNamesList.
Table.AddColumn..... each List.Sum(Record.FieldValues(Record.SelectFields(_, EstimateFieldNamesList))))
It is giving the required results, but it's EXTREMELY SLOW...
Any way to improve its performance?
Thanks again.
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Hi @karimm ,
yes, you can speed this up by buffereing the EstimateFieldNamesList.
Easiest way is to add another step:
BufferedList = List.Buffer(EstimateFieldNamesList)
and use this in your Table.AddColumn expression like so:
Table.AddColumn..... each List.Sum(Record.FieldValues(Record.SelectFields(_, BufferedList))))
Imke Feldmann (The BIccountant)
If you liked my solution, please give it a thumbs up. And if I did answer your question, please mark this post as a solution. Thanks!
How to integrate M-code into your solution -- How to get your questions answered quickly -- How to provide sample data -- Check out more PBI- learning resources here -- Performance Tipps for M-queries
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Thank you so much!
In the meantime, what I did is to unpivot those columns as they reflect values from a dimension, and use group by.
Whis was blazing fast!
Thanks again!
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
HI @Anonymous,
If you can please provide a pbix file for test, I think it will help for test and coding formula.(you can upload to onedrive or google drive and share link here)
Regards,
Xiaoxin Sheng
If this post helps, please consider accept as solution to help other members find it more quickly.
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Hi @Anonymous,
In my option, you can write a variable step to get table fields as list.
Then use that variable in in expression column name part which you mentioned as parameter to achieve dynamic fields name.
Regards,
Xiaoxin Sheng
If this post helps, please consider accept as solution to help other members find it more quickly.
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Please post sample data.
And next time, please reformat your post, as it is almost unreadable.
Imke Feldmann (The BIccountant)
If you liked my solution, please give it a thumbs up. And if I did answer your question, please mark this post as a solution. Thanks!
How to integrate M-code into your solution -- How to get your questions answered quickly -- How to provide sample data -- Check out more PBI- learning resources here -- Performance Tipps for M-queries
Helpful resources
Join us at the Microsoft Fabric Community Conference
March 31 - April 2, 2025, in Las Vegas, Nevada. Use code MSCUST for a $150 discount!
Microsoft Fabric Community Conference 2025
Arun Ulag shares exciting details about the Microsoft Fabric Conference 2025, which will be held in Las Vegas, NV.
Subject | Author | Posted | |
---|---|---|---|
07-18-2024 06:23 AM | |||
06-30-2023 05:14 PM | |||
12-13-2023 10:03 AM | |||
05-29-2024 02:54 AM | |||
04-05-2024 02:58 AM |
User | Count |
---|---|
113 | |
77 | |
55 | |
54 | |
43 |
User | Count |
---|---|
183 | |
120 | |
80 | |
67 | |
57 |