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

Earn a 50% discount on the DP-600 certification exam by completing the Fabric 30 Days to Learn It challenge.

Reply
zimme063
Regular Visitor

create table dynamically

I am using Power BI desktop and I need to deliver a tool for users to easily view their data.  I am intersted in creating a new table based on a filtered main table where the filter parameters is stored in a list.  The end goal is to have the main table parsed into subtables so the users can find data easilty by the Table->Field hierarchy in the Power BI field bar.

 

A simplified example  -

Input

Table_Attributes:  Attributes of fruit (each fruit has a different attributes in the table);

List_Fruit: [Apples, Bananas, Pineapples]; 

 

Output

Table_Attributes

List_Fruit

Table_Apples

Table_Bananas

Table_Pineapples

1 REPLY 1
Eric_Zhang
Employee
Employee


@zimme063 wrote:

I am using Power BI desktop and I need to deliver a tool for users to easily view their data.  I am intersted in creating a new table based on a filtered main table where the filter parameters is stored in a list.  The end goal is to have the main table parsed into subtables so the users can find data easilty by the Table->Field hierarchy in the Power BI field bar.

 

A simplified example  -

Input

Table_Attributes:  Attributes of fruit (each fruit has a different attributes in the table);

List_Fruit: [Apples, Bananas, Pineapples]; 

 

Output

Table_Attributes

List_Fruit

Table_Apples

Table_Bananas

Table_Pineapples


@zimme063

You can create the tables manually.

1.png2.PNG3.PNG4.PNG5.PNG

 

let
    Source = Table.SelectRows(Main_Table, each ([fruit] = "Apples")),
    tableApples = Table.SelectColumns(Source, Table.ToList(Table.SelectColumns(Table.SelectRows(Table_Attributes, each ([fruit] = "Apples")),"attributes")))

in
    tableApples
let
    Source = Table.SelectRows(Main_Table, each ([fruit] = "Bananas")),
    tableBananas = Table.SelectColumns(Source, Table.ToList(Table.SelectColumns(Table.SelectRows(Table_Attributes, each ([fruit] = "Bananas")),"attributes")))

in
    tableBananas
let
    Source = Table.SelectRows(Main_Table, each ([fruit] = "Pineapples")),
    tablePineapples = Table.SelectColumns(Source, Table.ToList(Table.SelectColumns(Table.SelectRows(Table_Attributes, each ([fruit] = "Pineapples")),"attributes")))

in
    tablePineapples

However I don't think you can create the tables dynamically according to the List_Fruit table. For me it doesn't make much sense, for example, provided the dynamically way would work, when the list_fruit table changes, after refreshing, there're more/less tables,  for newly added tables, they were not used in the  report visuals. For the missing tables, you reports would show errors. In my opinion, dynamical schema and metadata is not a good practice.

 

I guess we can get more proper suggestion in Power Query from @ImkeF. 🙂

 

Helpful resources

Announcements
LearnSurvey

Fabric certifications survey

Certification feedback opportunity for the community.

PBI_APRIL_CAROUSEL1

Power BI Monthly Update - April 2024

Check out the April 2024 Power BI update to learn about new features.

April Fabric Community Update

Fabric Community Update - April 2024

Find out what's new and trending in the Fabric Community.