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

Get Fabric Certified for FREE during Fabric Data Days. Don't miss your chance! Learn more

Reply
jvandyck
Helper IV
Helper IV

Positive and negative filter

I have a table with 2 fields listing company id and salary code id to indicate which company uses which salary codes.

This is a big tabel with over 230million rows. I want to add a positive and a negative filter on the usage of salary codes in order to be able to show companies using specific codes and not using specific codes. In power bi I can only create positive filters, but there has to be a workaround for this. Who can help me? 

1 ACCEPTED SOLUTION
Anonymous
Not applicable

Hi @jvandyck ,

I updated your sample pbix file(see attachment), please check if that is what you want.

1. Create two dimension table use the field [Salary Code] of table Sheet1

Positive codes = VALUES('Sheet1'[Salary Code])
Negative codes = VALUES('Sheet1'[Salary Code])

yingyinr_0-1654682484689.png

2. Apply the fields in above dimension tables on the slicers(Positive and Negative)

yingyinr_1-1654682574759.png

3. Create a measure as below to judge if the enterprise should display or not

Measure = 
VAR _selent =
    SELECTEDVALUE ( 'Sheet1'[Enterprise] )
VAR _positivecodes =
    ALLSELECTED ( 'Positive codes'[Salary Code] )
VAR _negativecodes =
    ALLSELECTED ( 'Negative codes'[Salary Code] )
VAR _count1 =
    CALCULATE (
        DISTINCTCOUNT ( 'Sheet1'[Enterprise] ),
        FILTER (
            'Sheet1',
            'Sheet1'[Enterprise] = _selent
                && 'Sheet1'[Flag] = 1
                && 'Sheet1'[Salary Code] = SELECTEDVALUE ( 'Negative codes'[Salary Code] )
        )
    )
VAR _tab1 =
    CALCULATETABLE (
        VALUES ( 'Sheet1'[Enterprise] ),
        FILTER (
            'Sheet1',
            'Sheet1'[Enterprise] = _selent
                && 'Sheet1'[Flag] = 1
                && IF (
                    ISFILTERED ( 'Positive codes'[Salary Code] ),
                    'Sheet1'[Salary Code] IN _positivecodes,
                    1 = 1
                )
        )
    )
VAR _tab2 =
    CALCULATETABLE (
        VALUES ( 'Sheet1'[Enterprise] ),
        FILTER (
            'Sheet1',
            'Sheet1'[Enterprise] = _selent
                && 'Sheet1'[Flag] = 1
                && IF (
                    ISFILTERED ( 'Negative codes'[Salary Code] ),
                    'Sheet1'[Salary Code] IN _negativecodes,
                    1 = 1
                )
        )
    )
RETURN
    IF (
        NOT ( ISFILTERED ( 'Negative codes'[Salary Code] ) ),
        IF ( _selent IN _tab1, 1, 0 ),
        IF ( _selent IN EXCEPT ( _tab1, _tab2 ), 1, 0 )
    )

4. Create a table visual with visual-level filter condition(Measure is 1)

yingyinr_2-1654682733929.png

Best Regards

View solution in original post

7 REPLIES 7
jvandyck
Helper IV
Helper IV

Here you can find a mock-up with a positive slicer and a negative slicer: https://acerta-my.sharepoint.com/:f:/g/personal/joos_van_dyck_acerta_be/ErGyDBRA9L5GlQVkN-tKoM4BGidi.... The test data is in the excel. 

If I want to show companies with code 1 and not 2, it should return company A.

If I want to show companies with code 4 and code 8, it should return companies B and C.

If I want to show companies without code 2, it should return A and C.

If I want to show companies with code 3 but not code 3, it should return A and C.

This logic should be expandable to multiselect both in the positive and in the negative filter.

 

Anonymous
Not applicable

Hi @jvandyck ,

I updated your sample pbix file(see attachment), please check if that is what you want.

1. Create two dimension table use the field [Salary Code] of table Sheet1

Positive codes = VALUES('Sheet1'[Salary Code])
Negative codes = VALUES('Sheet1'[Salary Code])

yingyinr_0-1654682484689.png

2. Apply the fields in above dimension tables on the slicers(Positive and Negative)

yingyinr_1-1654682574759.png

3. Create a measure as below to judge if the enterprise should display or not

Measure = 
VAR _selent =
    SELECTEDVALUE ( 'Sheet1'[Enterprise] )
VAR _positivecodes =
    ALLSELECTED ( 'Positive codes'[Salary Code] )
VAR _negativecodes =
    ALLSELECTED ( 'Negative codes'[Salary Code] )
VAR _count1 =
    CALCULATE (
        DISTINCTCOUNT ( 'Sheet1'[Enterprise] ),
        FILTER (
            'Sheet1',
            'Sheet1'[Enterprise] = _selent
                && 'Sheet1'[Flag] = 1
                && 'Sheet1'[Salary Code] = SELECTEDVALUE ( 'Negative codes'[Salary Code] )
        )
    )
VAR _tab1 =
    CALCULATETABLE (
        VALUES ( 'Sheet1'[Enterprise] ),
        FILTER (
            'Sheet1',
            'Sheet1'[Enterprise] = _selent
                && 'Sheet1'[Flag] = 1
                && IF (
                    ISFILTERED ( 'Positive codes'[Salary Code] ),
                    'Sheet1'[Salary Code] IN _positivecodes,
                    1 = 1
                )
        )
    )
VAR _tab2 =
    CALCULATETABLE (
        VALUES ( 'Sheet1'[Enterprise] ),
        FILTER (
            'Sheet1',
            'Sheet1'[Enterprise] = _selent
                && 'Sheet1'[Flag] = 1
                && IF (
                    ISFILTERED ( 'Negative codes'[Salary Code] ),
                    'Sheet1'[Salary Code] IN _negativecodes,
                    1 = 1
                )
        )
    )
RETURN
    IF (
        NOT ( ISFILTERED ( 'Negative codes'[Salary Code] ) ),
        IF ( _selent IN _tab1, 1, 0 ),
        IF ( _selent IN EXCEPT ( _tab1, _tab2 ), 1, 0 )
    )

4. Create a table visual with visual-level filter condition(Measure is 1)

yingyinr_2-1654682733929.png

Best Regards

important is that I can add multiple codes both on the positive and the negative side

mahenkj2
Solution Sage
Solution Sage

Hi @jvandyck ,

I would suggest you to add a sample of desired output.

amitchandak
Super User
Super User

@jvandyck , You can create two measures and create calculation groups

 

or a new column

if([salary] <0, "Negative", "Positive")

Share with Power BI Enthusiasts: Full Power BI Video (20 Hours) YouTube
Microsoft Fabric Series 60+ Videos YouTube
Microsoft Fabric Hindi End to End YouTube

thank you for your swift reply...but how can I then add 2 listbars, listing all salary codes, one as the positive filter and one as the negative filter to select the codes I want to use in my positive and negative filter?

@jvandyck , If this does not help
Can you share sample data and sample output in table format?

 

But I think calculation group can help

Calculation Groups- Measure Slicer, Measure Header Grouping, Measure to dimension conversion. Complex Table display: https://youtu.be/qMNv67P8Go0

Share with Power BI Enthusiasts: Full Power BI Video (20 Hours) YouTube
Microsoft Fabric Series 60+ Videos YouTube
Microsoft Fabric Hindi End to End YouTube

Helpful resources

Announcements
Fabric Data Days Carousel

Fabric Data Days

Advance your Data & AI career with 50 days of live learning, contests, hands-on challenges, study groups & certifications and more!

October Power BI Update Carousel

Power BI Monthly Update - October 2025

Check out the October 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.

Top Solution Authors