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

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

Reply
Anonymous
Not applicable

Calculation within column

Hello, 

 

I have data on municipality expenditures by year. There are also variables for the class of expenditure e.g. library services, and the account this expenditure is on. Example: 

 

MunicipalityExpenditureAccountAccount indexClassYear
Municipality 11000€Total costs1Library services2021
Municipality 1100€Staff costs2Library services2021
Municipality 1100€Grants3Library services2021
Municipality 23000€Total costs1Administration2021

 

There are only three possible accounts per each municipality/year/class. The problem is, the "total costs" sum includes the other account costs, and the row sum per class or per municipality will sum up to more than what are the true total costs. So what I want to do is to create a new column with new accounts: staff costs, grants, and "other costs", where staff costs and grants are subtracted from the total costs in order to obtain "other costs". My strongest idea is to index the rows by municipality/class/year, and create "other costs" column which references the sorted Account -row and subtracts 2 and 3 from 1 and places this on the index 1 row. On the index 2 row, i want to place the unchanged staff costs etc, so that the row sum will then reflect the total cost. There are plenty of instructions on how to create differences between consecutive rows, but not on more complex calculations. I am stuck on this since I am new to powerBI.

Any help is greatly appreciated, thanks. 

1 ACCEPTED SOLUTION
FreemanZ
Super User
Super User

Hi @Anonymous 

 

i am not sure if i understand your requirement complete, please try to create a table with this:

Table =
VAR _table1 =
    SUMMARIZE(
        TableName,
        TableName[Municipality],
        TableName[Class],
        TableName[Year],
        TableName[Account],
        TableName[Account index]
    )
       
VAR _table2 =
ADDCOLUMNS(
    _table1,
    "Expenditure",  
    IF(
        TableName[Account index]=1,
        CALCULATE(
            SUM(TableName[Expenditure]),
            TableName[Account] = "Total costs"
        )-
        CALCULATE(
            SUM(TableName[Expenditure]),
            TableName[Account] <> "Total costs",
            VALUES(TableName[Account index])
        ),
        MIN(TableName[Expenditure])
   
    )
)

RETURN _table2
 
I tried and it worked like this:
FreemanZ_2-1670507087169.png

 


 

View solution in original post

2 REPLIES 2
FreemanZ
Super User
Super User

Hi @Anonymous 

 

i am not sure if i understand your requirement complete, please try to create a table with this:

Table =
VAR _table1 =
    SUMMARIZE(
        TableName,
        TableName[Municipality],
        TableName[Class],
        TableName[Year],
        TableName[Account],
        TableName[Account index]
    )
       
VAR _table2 =
ADDCOLUMNS(
    _table1,
    "Expenditure",  
    IF(
        TableName[Account index]=1,
        CALCULATE(
            SUM(TableName[Expenditure]),
            TableName[Account] = "Total costs"
        )-
        CALCULATE(
            SUM(TableName[Expenditure]),
            TableName[Account] <> "Total costs",
            VALUES(TableName[Account index])
        ),
        MIN(TableName[Expenditure])
   
    )
)

RETURN _table2
 
I tried and it worked like this:
FreemanZ_2-1670507087169.png

 


 

Anonymous
Not applicable

Hi @FreemanZ, Your table seems to do exactly what I want. I also managed to solve this by creating a new column and using switch and several filters. Thanks for the help anyway! 

Helpful resources

Announcements
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.