Skip to main content
cancel
Showing results for 
Search instead for 
Did you mean: 

Power BI is turning 10! Let’s celebrate together with dataviz contests, interactive sessions, and giveaways. Register now.

Reply
Mic1979
Post Partisan
Post Partisan

Dynamic Filter Based on Column Name

Hello,

 

I have the following table:

Mic1979_0-1748709543230.png

and I would like to apply a filter based on the column name, e.g. Distribution.

I was trying to write the following code:

 

SelectDistributionColumn = List.Select (Table.ColumnNames (RemovedColumn), each Text.Contains (_, "Distribution")),

FilteredTable = Table.SelectRows (Previous_Step, each Record.Field(_, SelectDistributionColumn) <>0)

 

but this is not working.

 

Could you help?

 

Thanks

 

1 ACCEPTED SOLUTION

One method is to add a "Filter Column" which will return True or false depending on your logic. Then filter on that column.

 

For example, the following code would add a column name'd "Filter"

#"Add Filter Column" = Table.AddColumn(PreviousStep,"Filter", (r)=> 

    //Use List.AllTrue if you want "and" logic
    //Use List.AnyTrue if you want "or" logic
        List.AllTrue(
            
            List.Transform(
                Record.FieldValues(
                    Record.SelectFields(
                        r,SelectDistributionColumn)), 
            each _ <> 0 and _ <> null)))

 

Then Filter on that column for true or false.

View solution in original post

4 REPLIES 4
ronrsnfld
Super User
Super User

SelectDistributionColumn is a List, but needs to be a text string, as indicated by the error message you most likely received.

 

If there is just a single column, then just use the first element of that list.

If there are multiple columns, then you have to reference each column separately.

The are multiple columns, and I want to reference to the selected column by the column name.

Could you suggest the code?

 

Thanks.

One method is to add a "Filter Column" which will return True or false depending on your logic. Then filter on that column.

 

For example, the following code would add a column name'd "Filter"

#"Add Filter Column" = Table.AddColumn(PreviousStep,"Filter", (r)=> 

    //Use List.AllTrue if you want "and" logic
    //Use List.AnyTrue if you want "or" logic
        List.AllTrue(
            
            List.Transform(
                Record.FieldValues(
                    Record.SelectFields(
                        r,SelectDistributionColumn)), 
            each _ <> 0 and _ <> null)))

 

Then Filter on that column for true or false.

Thanks.

Helpful resources

Announcements
Join our Fabric User Panel

Join our Fabric User Panel

This is your chance to engage directly with the engineering team behind Fabric and Power BI. Share your experiences and shape the future.

June 2025 Power BI Update Carousel

Power BI Monthly Update - June 2025

Check out the June 2025 Power BI update to learn about new features.

June 2025 community update carousel

Fabric Community Update - June 2025

Find out what's new and trending in the Fabric community.

Top Solution Authors