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

Join the Fabric FabCon Global Hackathon—running virtually through Nov 3. Open to all skill levels. $10,000 in prizes! 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
FabCon Global Hackathon Carousel

FabCon Global Hackathon

Join the Fabric FabCon Global Hackathon—running virtually through Nov 3. Open to all skill levels. $10,000 in prizes!

September Power BI Update Carousel

Power BI Monthly Update - September 2025

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

FabCon Atlanta 2026 carousel

FabCon Atlanta 2026

Join us at FabCon Atlanta, March 16-20, for the ultimate Fabric, Power BI, AI and SQL community-led event. Save $200 with code FABCOMM.