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,
Looking for help in the following scenario:
I want to replace null value in the column with the average value of the column. How can I achieve this? I am interested in using conditional column or something of this sort.
Regards,
Vivek
Solved! Go to Solution.
Hi @vivran22 ,
let Source = YourTable, #"SetType" = Table.TransformColumnTypes(#"Source ",{{"Sample", type number}}), #"ReplaceAvg" = Table.ReplaceValue(#"SetType",null,List.Average(#"SetType"[Sample]),Replacer.ReplaceValue,{"Sample"}) in ReplaceAvg
Is this ok ? I assumed your initial table is YourTable and the column is named "Sample"
Tell me if there is any problem.
Regards,
Etienne
can you upload some sample data? if not, basically:
That should put the average where nulls used to be.
@Anonymous
Thank you, Nick for your response. The challenge with the resposne you shared is that it is not dynamic. If in case, there are additional rows of data, then the average value of the column will change. The need is to make it dynamic, ie using Power Query/M I can calculate the average of the column and then replaces all the null values with it instead of calculating average manually.
Regards,
Vivek
sure, DAX and M can pretty much do anything within reason. Can you upload a sample pbix file?
@Anonymous
I won't be able to share the exact data file, but following is what I am looking for:
This is the sample data:
Sample 1 |
1 |
2 |
3 |
4 |
null |
5 |
The requirement is that the null should be replaced as 3 (average of the dataset)
and in case there are addition in the table then null should update accordingly:
Sample 2 |
1 |
2 |
3 |
4 |
null |
5 |
6 |
7 |
In Sample 2, the null should be replaced as 4.
Hope this helps.
Rgds,
Vivek
Hi @vivran22 ,
let Source = YourTable, #"SetType" = Table.TransformColumnTypes(#"Source ",{{"Sample", type number}}), #"ReplaceAvg" = Table.ReplaceValue(#"SetType",null,List.Average(#"SetType"[Sample]),Replacer.ReplaceValue,{"Sample"}) in ReplaceAvg
Is this ok ? I assumed your initial table is YourTable and the column is named "Sample"
Tell me if there is any problem.
Regards,
Etienne
Hi,
How can I expand the script, to calculate the average by another column? So don't just want the average of the whole column, I want the average by another category (see below fruit type):
Fruit type | Value | average by fruit type (no need this column, its just a representation) |
apple | 1 | |
apple | 2 | |
apple | null | expected result: 1,5 |
orange | 3 | |
orange | 5 | |
orange | null | expected result: 4 |
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 | |
12 | |
8 | |
8 | |
7 |
User | Count |
---|---|
15 | |
13 | |
9 | |
7 | |
6 |