Find everything you need to get certified on Fabric—skills challenges, live sessions, exam prep, role guidance, and more. Get started
I am very new to PowerBI and have been tasked with recreating all of our reports from QlikSense.
I was able to get a defect rate and now need to add multiple AND and OR filters. I am struggling. Below is my Defect Rate calculation and the error message I get. I also need to add in a Filter for vSalesMaster,vSalesMaster[DefectReason] is not equal to AB Damage, Freight Damage, and Concealed Damage.
DefectRate = DIVIDE(
CALCULATE(
SUM ( vSalesMaster[WarrDetail.InvoiceQty] ),
FILTER (vSalesMaster,vSalesMaster[OrderType] = "W"),
FILTER (vSalesMaster,vSalesMaster[WarrDetail.DaysInField] <= "30")
),
CALCULATE(
SUM ( [InvoiceQty] ),
FILTER (VSalesMaster,vSalesMaster[OrderType] = "R")
))
Solved! Go to Solution.
The error you are getting seems related to trying to compare a Text value with a Numeric value. My guess would be that you need to remove the double quotes around your numeric value of 30.
@Anonymous
In your formula, the issue is on the logic of your applied filter, your logic like: [Column]<>"A" || [Column]<>"B" will return you all values in [Column], which means this filter doesn't work at all.
Based on your description, you should apply AND logic between those "not equal" conditions:
UnfilterDefectRate = DIVIDE ( CALCULATE ( SUM ( vSalesMaster[WarrDetail.InvoiceQty] ), FILTER ( vSalesMaster, vSalesMaster[OrderType] = "W" && vSalesMaster[WarrDetail.DefectReason] <> "AB Damage" && vSalesMaster[WarrDetail.DefectReason] <> "Concealed Damage" && vSalesMaster[WarrDetail.DefectReason] <> "Claim Filed" && vSalesMaster[WarrDetail.DefectReason] <> "Freight Damage" && vSalesMaster[WarrDetail.DefectReason] <> "Goodwill" ) ), CALCULATE ( SUM ( [InvoiceQty] ), FILTER ( VSalesMaster, vSalesMaster[OrderType] = "R" ) ) )
Regards,
Thank you SO much. I am new to Power BI and the easiest things are tripping me up. 🙂
The error you are getting seems related to trying to compare a Text value with a Numeric value. My guess would be that you need to remove the double quotes around your numeric value of 30.
Thank you so much. That took care of the error message.
Do you know anything about the adding the additional filters?
You can combine multiple filters like this:
OpenTickets = CALCULATE(COUNTROWS(Tickets),FILTER(Tickets,(Tickets[create_ticket]<=[Dates] && ISBLANK(Tickets[close_ticket_date]) || (Tickets[create_ticket]<=[Dates] && Tickets[close_ticket_date]>=[Dates]))))
I have added in the filters and I am getting an error message:A function 'FILTER' has been used in a True/False expression that is used as a table filter expression. This is not allowed. Can you help me?
UnfilterDefectRate = DIVIDE(
CALCULATE(
SUM ( vSalesMaster[WarrDetail.InvoiceQty] ),
FILTER (vSalesMaster,vSalesMaster[OrderType] = "W" &&
vSalesMaster[WarrDetail.DefectReason] <> "AB Damage" ) ||
(vSalesMaster[OrderType] = "W" &&
vSalesMaster[WarrDetail.DefectReason] <> "Concealed Damage" ) ||
(vSalesMaster[OrderType] = "W" &&
vSalesMaster[WarrDetail.DefectReason] <> "Claim Filed" ) ||
(vSalesMaster[OrderType] = "W" &&
vSalesMaster[WarrDetail.DefectReason] <> "Freight Damage" ) ||
(vSalesMaster[OrderType] = "W" &&
vSalesMaster[WarrDetail.DefectReason] <> "Goodwill" )
),
CALCULATE(
SUM ( [InvoiceQty] ),
FILTER (VSalesMaster,vSalesMaster[OrderType] = "R")
)
)
@Anonymous
In your formula, the issue is on the logic of your applied filter, your logic like: [Column]<>"A" || [Column]<>"B" will return you all values in [Column], which means this filter doesn't work at all.
Based on your description, you should apply AND logic between those "not equal" conditions:
UnfilterDefectRate = DIVIDE ( CALCULATE ( SUM ( vSalesMaster[WarrDetail.InvoiceQty] ), FILTER ( vSalesMaster, vSalesMaster[OrderType] = "W" && vSalesMaster[WarrDetail.DefectReason] <> "AB Damage" && vSalesMaster[WarrDetail.DefectReason] <> "Concealed Damage" && vSalesMaster[WarrDetail.DefectReason] <> "Claim Filed" && vSalesMaster[WarrDetail.DefectReason] <> "Freight Damage" && vSalesMaster[WarrDetail.DefectReason] <> "Goodwill" ) ), CALCULATE ( SUM ( [InvoiceQty] ), FILTER ( VSalesMaster, vSalesMaster[OrderType] = "R" ) ) )
Regards,
Check out the September 2024 Power BI update to learn about new features.
Learn from experts, get hands-on experience, and win awesome prizes.
User | Count |
---|---|
113 | |
109 | |
100 | |
39 | |
31 |
User | Count |
---|---|
154 | |
122 | |
77 | |
74 | |
44 |