cancel
Showing results for 
Search instead for 
Did you mean: 
Reply
Regular Visitor

Need help to get the conditional average in power query

Hi,

I am a newbie to PowerQuery. I need a M Query solution to the below problem

Suppose I have a Country column, Value column. Now I wanted to average the Value column not equal to 0, for each country in the country column.  Kindly see the below example.

anvikuttu_0-1600515234584.png

 

Let me know if you have any questions.

 

Thank you...

Vj

2 ACCEPTED SOLUTIONS

Accepted Solutions
Resident Rockstar
Resident Rockstar

Hi, Fowmy's solution surely works. When your dataset consists of 2k+ rows, you might try this,

let
    Source = Table.FromRows(Json.Document(Binary.Decompress(Binary.FromText("i45WCg1W0lEyNFCK1YGxTRFsIyQ2VIk3SBiJDVPuDVfiGIrKNERmQ1Q7OyLEwWwgMxYA", BinaryEncoding.Base64), Compression.Deflate)), let _t = ((type nullable text) meta [Serialized.Text = true]) in type table [Country = _t, Value = _t]),

    #"Added Custom" = Table.AddColumn(Source, "Custom", each Table.Group(Source, {"Country"}, {{"grouped", each _}}){[Country = [Country]]}[grouped][Value]),
    Avg = Table.TransformColumns(#"Added Custom", {{"Custom", each List.Average(List.RemoveItems(List.Transform(_, Number.From), {0}))}})
in
    Avg

View solution in original post

Hello

 

the simplest thing is to include all in ONE Group-Step... the average except 0 and All rows (to keep the value-column for later)

Check it out

let
    Source = Table.FromRows(Json.Document(Binary.Decompress(Binary.FromText("i45WCg1W0lEyNFCK1YGxTRFsIyQ2VIk3SBiJDVPuDVfiGIrKNERmQ1Q7OyLEwWwgMxYA", BinaryEncoding.Base64), Compression.Deflate)), let _t = ((type nullable text) meta [Serialized.Text = true]) in type table [Country = _t, Value = _t]),
    #"Changed Type" = Table.TransformColumnTypes(Source,{{"Value", type number}}),
    #"Grouped Rows" = Table.Group(#"Changed Type", {"Country"}, {{"Average", each List.Average(List.Select([Value], each _ >0)), type number}, {"AllRows", each _, type table [Country=text, Value=number]}}),
    #"Expanded AllRows" = Table.ExpandTableColumn(#"Grouped Rows", "AllRows", {"Value"}, {"Value"})
in
    #"Expanded AllRows"

 

This function of the group-function makes the average without 0

{"Average", each List.Average(List.Select([Value], each _ >0)), type number}

 

Copy paste this code to the advanced editor in a new blank query to see how the solution works.

If this post helps or solves your problem, please mark it as solution (to help other users find useful content and to acknowledge the work of users that helped you)
Kudoes are nice too

Have fun

Jimmy

View solution in original post

6 REPLIES 6
Community Champion
Community Champion

@anvikuttu 

Click Add Column < Custom and paste the below code to get the average excluding zero and by country.

(r)=> 
List.Average(
Table.SelectRows(#"Changed Type", each [VALUE] <> 0 and [COUNTRY] = r[COUNTRY])[VALUE])

Fowmy_0-1600517421919.png

________________________

If my answer was helpful, please consider Accept it as the solution to help the other members find it

Click on the Thumbs-Up icon if you like this reply 🙂

YouTube  LinkedIn

Resident Rockstar
Resident Rockstar

Hi, Fowmy's solution surely works. When your dataset consists of 2k+ rows, you might try this,

let
    Source = Table.FromRows(Json.Document(Binary.Decompress(Binary.FromText("i45WCg1W0lEyNFCK1YGxTRFsIyQ2VIk3SBiJDVPuDVfiGIrKNERmQ1Q7OyLEwWwgMxYA", BinaryEncoding.Base64), Compression.Deflate)), let _t = ((type nullable text) meta [Serialized.Text = true]) in type table [Country = _t, Value = _t]),

    #"Added Custom" = Table.AddColumn(Source, "Custom", each Table.Group(Source, {"Country"}, {{"grouped", each _}}){[Country = [Country]]}[grouped][Value]),
    Avg = Table.TransformColumns(#"Added Custom", {{"Custom", each List.Average(List.RemoveItems(List.Transform(_, Number.From), {0}))}})
in
    Avg

View solution in original post

Hi @CNENFRNL ,

Could you please help me understand the 2nd and 3rd step?

Also kindly let me know the best way to learn the power query... I followed a book to learn, but it looks like I don't know anything 😞

 

Thanks and regards,

Vj

Hi, @anvikuttu , in my code, step 2 and 3 finish the following tasks respectively,

step 2 adds an extra column; in this column each row contains a list of all values of the same country;

step 3 averages the list in step 2 excluding 0.

 

As to the study of M language, I myself is also a learner for half of a year or so. I recommend such a roadmap,

Study fundamental concepts of M, in particular, table/list/record, relationships and conversions from one to another;

Spend some time studying codes by UI;

Try to master some most frequently used functions such as Tabel.AddColumn, Table.TransformColumns, etc.

Use advanced editor to practise user defined functions.

Hello

 

the simplest thing is to include all in ONE Group-Step... the average except 0 and All rows (to keep the value-column for later)

Check it out

let
    Source = Table.FromRows(Json.Document(Binary.Decompress(Binary.FromText("i45WCg1W0lEyNFCK1YGxTRFsIyQ2VIk3SBiJDVPuDVfiGIrKNERmQ1Q7OyLEwWwgMxYA", BinaryEncoding.Base64), Compression.Deflate)), let _t = ((type nullable text) meta [Serialized.Text = true]) in type table [Country = _t, Value = _t]),
    #"Changed Type" = Table.TransformColumnTypes(Source,{{"Value", type number}}),
    #"Grouped Rows" = Table.Group(#"Changed Type", {"Country"}, {{"Average", each List.Average(List.Select([Value], each _ >0)), type number}, {"AllRows", each _, type table [Country=text, Value=number]}}),
    #"Expanded AllRows" = Table.ExpandTableColumn(#"Grouped Rows", "AllRows", {"Value"}, {"Value"})
in
    #"Expanded AllRows"

 

This function of the group-function makes the average without 0

{"Average", each List.Average(List.Select([Value], each _ >0)), type number}

 

Copy paste this code to the advanced editor in a new blank query to see how the solution works.

If this post helps or solves your problem, please mark it as solution (to help other users find useful content and to acknowledge the work of users that helped you)
Kudoes are nice too

Have fun

Jimmy

View solution in original post

Solution Supplier
Solution Supplier

@anvikuttu 

Try this:

// output
let
    Source = Table.FromRecords(Json.Document(Binary.Decompress(Binary.FromText("i65Wcs4vzSspqlSyUgoNVtJRCkvMKU1VsjI0qNXBKWeKW84Ijxy6kd5I2vDIYVjnjdNIx1CipNA9hyKHZpuzI259yHIGtbEA", BinaryEncoding.Base64),Compression.Deflate))),
    group = Table.Group(Source, {"Country"}, {"Foo", each Table.SplitColumn(_, "Value", (val)=>{val, List.Average(List.RemoveItems([Value], {0}))}, {"Value", "Avg"}), type table}),
    result = Table.Combine(group[Foo])
in
    result

Helpful resources

Announcements
Community Conference

Power Platform Community Conference

Check out the on demand sessions that are available now!

Community Conference

Microsoft Power Platform Communities

Check out the Winners!

secondImage

Create an end-to-end data and analytics solution

Learn how Power BI works with the latest Azure data and analytics innovations at the digital event with Microsoft CEO Satya Nadella.

Top Solution Authors
Top Kudoed Authors