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!The Power BI Data Visualization World Championships is back! Get ahead of the game and start preparing now! Learn more
I have a function in a dataflow that when invoked creates a computed table. However, if the same steps a followed without invoking a function, the table is not a computed table. I'm hoping someone can explain why this is the case and hopefully provide a workaround.
The function generates a list of numbers from two parameters StartNumber to EndNumber inclusive.
ListOfNumbersFunction:
let
NumberParameters = (StartNumber, EndNumber) =>
let
Source = #table(type table [#"Start Number"=Int64.Type, #"End Number"=Int64.Type],{{StartNumber,EndNumber}}),
#"Added List Length" = Table.AddColumn(Source, "List Length", each [End Number]-[Start Number]+1, Int64.Type),
#"Added Number List" = Table.AddColumn(#"Added List Length", "Number List", each List.Numbers([Start Number], [List Length], 1), type list),
#"Expanded Number List" = Table.ExpandListColumn(#"Added Number List", "Number List"),
#"Changed column type" = Table.TransformColumnTypes(#"Expanded Number List", {{"Number List", Int64.Type}}),
#"Removed other columns" = Table.SelectColumns(#"Changed column type", {"Number List"})
in
#"Removed other columns"
in
NumberParameters
Invoked function:
let
Source = ListOfNumbersFunction(5, 60)
in
Source
The invoked function returns a ‘calculated table’ with a list of numbers starting at 5 and ending with 60
However, this code returns a normal table:
let
Source = #table(type table [#"Start Number"=Int64.Type, #"End Number"=Int64.Type],{{5,60}}),
#"Added List Length" = Table.AddColumn(Source, "List Length", each [End Number]-[Start Number]+1, Int64.Type),
#"Added Number List" = Table.AddColumn(#"Added List Length", "Number List", each List.Numbers([Start Number], [List Length], 1), type list),
#"Expanded Number List" = Table.ExpandListColumn(#"Added Number List", "Number List"),
#"Changed column type" = Table.TransformColumnTypes(#"Expanded Number List", {{"Number List", Int64.Type}}),
#"Removed other columns" = Table.SelectColumns(#"Changed column type", {"Number List"})
in
#"Removed other columns"
I am keen to understand why calling the function makes the output table a computed table.
Thanks in advance
Dan
Solved! Go to Solution.
I was able to resolve this by saving the dataflow and then re-editing it again. No idea of the original cause.
I was able to resolve this by saving the dataflow and then re-editing it again. No idea of the original cause.
The Power BI Data Visualization World Championships is back! Get ahead of the game and start preparing now!