March 31 - April 2, 2025, in Las Vegas, Nevada. Use code MSCUST for a $150 discount! Early bird discount ends December 31.
Register NowBe one of the first to start using Fabric Databases. View on-demand sessions with database experts and the Microsoft product team to learn just how easy it is to get started. Watch now
Imagine a classic hierarchy often used in Excel or how people naturally perceive it. For example, consider an "Income Statement Item" or a cash flow registry. Here, we have income and expenses, which are broken down into smaller components. This is the hierarchy as humans see it.
Now, let’s switch to how a computer interprets hierarchy. On the second sheet of our Excel file, you’ll see the hierarchical structure represented in a computer-friendly format. It typically involves three columns: ID, Parent ID, and Income Statement Item.
For instance:
In accounting systems, hierarchical directories are written as rows and cascaded for processing.
Problem: Raw Registry Data
The third sheet of our Excel file contains raw registry data, showing lower-level Income Statement Items along with their amounts. However, this data isn’t easy to interpret. Income and expenses are mixed together, making it hard to understand trends.
Solution: Decoding the Hierarchical Directory in Power BI
We can resolve this by leveraging Power BI. While the task is simple, it’s an essential use case, as there are many hierarchical directories like catalogs, contractors, and more that need to be deciphered in analytics.
Here’s how to get started:
2. Establish Relationships
3. Create a Matrix Visualization
- Drag Income Statement Item (from the Hierarchy table) to Rows.
- Drag Amount (from the Registry table) to Values.
This will display the raw data as it comes from accounting systems. However, it’s still not very user-friendly.
Enhancing the Report with DAX
Let’s transform the data using DAX formulas to better represent the hierarchy.
Step 1: Create a Path Column
We’ll use the PATH function to generate the hierarchy path.
Path = PATH('Hierarchy'[ID], 'Hierarchy'[Parent ID])
This function creates a path string, separating hierarchy levels with a vertical bar (|).
Now, let’s add calculated columns for specific levels using the PATHITEM function.
For Level 1, write:
Level 1 = PATHITEM(PATH('Hierarchy'[ID], 'Hierarchy'[Parent ID]), 1, INTEGER)
This retrieves the first element of the hierarchy (e.g., 1 – Revenues).
For Level 2 and Level 3, modify the position parameter:
Level 2 = PATHITEM(PATH('Hierarchy'[ID], 'Hierarchy'[Parent ID]), 2, INTEGER) Level 3 = PATHITEM(PATH('Hierarchy'[ID], 'Hierarchy'[Parent ID]), 3, INTEGER)
Step 3: Add Descriptive Names
Use LOOKUPVALUE to map IDs to their descriptions:
Level 1 Description = LOOKUPVALUE('Hierarchy'[Income Statement Item], 'Hierarchy'[ID],
PATHITEM(PATH('Hierarchy'[ID], 'Hierarchy'[Parent ID]), 1, INTEGER))
Repeat this for other levels by changing the path position.
Visualizing the Enhanced Hierarchy
1. Update your Matrix Visualization:
- AddLevel 1 and Level 2 descriptions to Rows.
- Drag Amount toValues.
2. Expand the hierarchy by clicking the “Expand to the lowest level” button.
Now, you’ll see your Income Statement in a clean, structured format, categorized both classically and hierarchically. This transformation makes the report far more insightful and actionable.
Hierarchical directories are a common feature in analytics, whether for items, contractors, or other datasets. Understanding how to decode and present them in tools like Power BI is an essential skill. With the combination of PATH, PATHITEM, and LOOKUPVALUE, you can make even the most complex hierarchies comprehensible.
Let us know if you found this guide helpful!
You must be a registered user to add a comment. If you've already registered, sign in. Otherwise, register and sign in.