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
PaisleyPrince
Helper III
Helper III

Calculate running sum of previous n rows

Hi,

I'm trying to create a loop in power query to calculate the total of the previous 8 rows as per the screenshot below. Any advice would be much appreciated.

thanks

Scott

sm1.png

3 ACCEPTED SOLUTIONS
shafiz_p
Super User
Super User

Hi @PaisleyPrince  Try this in custom column:

= if [Index] < 8 then "" else List.Sum(List.Range(#"Changed Type"[Value], [Index] - 8, 8))

 

See image:

shafiz_p_0-1732419240736.png

 

 

 

Hope this helps!!

If this solved your problem, please accept it as a solution and a kudos!!

 

 

Best Regards,
Shahariar Hafiz

View solution in original post

AlienSx
Super User
Super User

this one works 100 times (literally - one hundred times) faster on a small set of 5000 rows.

let
    Source = Excel.CurrentWorkbook(){[Name="Table1"]}[Content], 
    values = List.Buffer(Source[Value]),
    rt = List.Generate(
        () => [i = 0, ttl = values{0}],
        (x) => x[i] < List.Count(values),
        (x) => [i = x[i] + 1, ttl = x[ttl] + values{i}],
        (x) => x[ttl]
    ), 
    last_n = List.Transform(List.Zip({rt, List.Repeat({null}, 8 - 1) & {0} & List.RemoveLastN(rt, 8)}), (x) => x{0} - x{1}),
    result = Table.FromColumns(Table.ToColumns(Source) & {last_n}, Table.ColumnNames(Source) & {"Running Sum"})
in
    result

 

View solution in original post

slorin
Super User
Super User

Hi @PaisleyPrince 

 

Adapt @shafiz_p's  solution with List.Buffer

simplier but twice slower than @AlienSx 's proposition with 20000 rows

 

let
Source = YourSource,
Values = List.Buffer(Source[Value]),
#"Running Sum" = Table.AddColumn(Source, "Running Sum",
each if [Index] < 8 then "" else List.Sum(List.Range(Values, [Index] - 8, 8)))
in
#"Running Sum"

Stéphane

View solution in original post

5 REPLIES 5
slorin
Super User
Super User

Hi @PaisleyPrince 

 

Adapt @shafiz_p's  solution with List.Buffer

simplier but twice slower than @AlienSx 's proposition with 20000 rows

 

let
Source = YourSource,
Values = List.Buffer(Source[Value]),
#"Running Sum" = Table.AddColumn(Source, "Running Sum",
each if [Index] < 8 then "" else List.Sum(List.Range(Values, [Index] - 8, 8)))
in
#"Running Sum"

Stéphane

AlienSx
Super User
Super User

this one works 100 times (literally - one hundred times) faster on a small set of 5000 rows.

let
    Source = Excel.CurrentWorkbook(){[Name="Table1"]}[Content], 
    values = List.Buffer(Source[Value]),
    rt = List.Generate(
        () => [i = 0, ttl = values{0}],
        (x) => x[i] < List.Count(values),
        (x) => [i = x[i] + 1, ttl = x[ttl] + values{i}],
        (x) => x[ttl]
    ), 
    last_n = List.Transform(List.Zip({rt, List.Repeat({null}, 8 - 1) & {0} & List.RemoveLastN(rt, 8)}), (x) => x{0} - x{1}),
    result = Table.FromColumns(Table.ToColumns(Source) & {last_n}, Table.ColumnNames(Source) & {"Running Sum"})
in
    result

 

Anonymous
Not applicable

Hi @PaisleyPrince ,

It looks like shafiz_p's answer can help you solve your problem. If solved please accept the reply in this post which you think is helpful as a solution to help more others facing the same problem to find a solution quickly, thank you very much!

Best Regards,
Dino Tao

Omid_Motamedise
Super User
Super User

= if [Index] < 8 then "" else List.Sum(List.LastN(List.FirstN(Source[Value], [Index] ), 8))

 


If my answer helped solve your issue, please consider marking it as the accepted solution.
shafiz_p
Super User
Super User

Hi @PaisleyPrince  Try this in custom column:

= if [Index] < 8 then "" else List.Sum(List.Range(#"Changed Type"[Value], [Index] - 8, 8))

 

See image:

shafiz_p_0-1732419240736.png

 

 

 

Hope this helps!!

If this solved your problem, please accept it as a solution and a kudos!!

 

 

Best Regards,
Shahariar Hafiz

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 Kudoed Authors