Power BI Slicer for Multi-Value Columns: Splitting Delimited Data for Better Filtering
In this article, we will create a slicer based on a data column containing multiple entries separated by a delimiter. The goal is for the slicer to display each entry as an individual item, allowing users to filter data without selecting each grouped entry manually.
data:image/s3,"s3://crabby-images/975e2/975e2b3f5cb09ce76961fd5ce15c751744efda5c" alt="Baseline Report"
As an example, the sample data is an asset inventory with each asset owned by one or more named individuals. In instances where an asset is owned by multiple individuals, their names are delimited by a semicolon. An individual may be an owner of one or more assets.
In our sample data, the individual named “Clark, Ethan” is listed as the singular owner of the assets named “QuickBolt” and “VersaBox” and the co-owner, with “Taylor, Benjamin”, of the asset named “SnapWorks”. If we add a slicer using the Contacts
field in our sample data, both entries for “Clark, Ethan” and “Clark, Ethan; Taylor, Benjamin” need to be selected to find all assets owned by “Clark, Ethan”. The goal of this exercise is to create a slicer allowing the user to select “Clark, Ethan” to display all of that owner’s assets regardless of co-ownership.
data:image/s3,"s3://crabby-images/d7a66/d7a66fc808b107f2009a7046805a0007336b1ef4" alt="Unexpected Slicer Result: Missing Co-owned Entries"
For this exercise, the source data is in a table named TBL_INVENTORY
, with two columns: Asset
and Contacts
.
data:image/s3,"s3://crabby-images/9c676/9c6763e72444b8849f3d0ab86249470c9ea83211" alt="Inventory Table"
Instructions
Preparing the Slicer Data
We need to create a new table with individual entries for the slicer. The query below splits grouped entries using a delimiter. For reference, the full query is provided with step-by-step explanations. Both the query and the resulting table are named TBL_CONTACTS
.
let
Source = TBL_INVENTORY,
#"Removed Other Columns" = Table.SelectColumns(Source,{"Contacts"}),
#"Duplicated Column" = Table.DuplicateColumn(#"Removed Other Columns", "Contacts", "Contacts - Copy"),
#"Split Column by Delimiter" = Table.ExpandListColumn(Table.TransformColumns(#"Duplicated Column", {{"Contacts - Copy", Splitter.SplitTextByDelimiter(";", QuoteStyle.Csv), let itemType = (type nullable text) meta [Serialized.Text = true] in type {itemType}}}), "Contacts - Copy"),
#"Trimmed Text" = Table.TransformColumns(#"Split Column by Delimiter",{{"Contacts - Copy", Text.Trim, type text}}),
#"Removed Duplicates" = Table.Distinct(#"Trimmed Text")
in
#"Removed Duplicates"
Source Data
We start by creating a blank query:
- From the
Home
ribbon in Power BI, clickGet data
and selectBlank query
. - The Power Query window is displayed.
- Set the initial data source by entering
= TBL_INVENTORY
in the command field.
data:image/s3,"s3://crabby-images/9726e/9726e28663f4c9af5f68c0f52b4da63f7e361453" alt="Query Source Data"
Remove Other Columns
Next, keep only the Contacts
column:
- Highlight the
Contacts
column. - From the
Home
ribbon, clickRemove Columns
and selectRemove Other Columns
.
data:image/s3,"s3://crabby-images/6af9c/6af9c8e0fc1d4cba302f49b800d13997644dd4f3" alt="Remove Other Columns"
Duplicate Column
At this stage, only the Contacts
column remains.
- From the
Add Column
ribbon, clickDuplicate Column
. - We now have two column labeled
Contacts
andContacts - Copy
.
data:image/s3,"s3://crabby-images/c0e34/c0e34b402d8454f8824879942db4190f17944b92" alt="Duplicate Column"
Split Column
- Highlight the
Contacts - Copy
column. - From the
Transform
ribbon, clickSplit Column
and selectBy Delimiter
. - The
Split Column by Delimiter
dialog box is displayed.
data:image/s3,"s3://crabby-images/7c2c1/7c2c1d2ecde00cc0882869052e730ce120a19012" alt="Split Column By Delimiter Configuration"
- In our sample data, the delimiter is a semicolon. In the
Select or enter delimiter
, selectSemicolon
. - For the
Split at
dropdown, selectEach occurrence of the delimiter
. - Expand the
Advanced options
. - Under
Split into
, selectRows
. - Click the
OK
button.
data:image/s3,"s3://crabby-images/012aa/012aa31cb7ef1955e461a8bee9b8f51ba0691184" alt="Split Column By Delimiter"
Trim Text
- Highlight the
Contacts - Copy
column. - From the
Add Column
ribbon, clickFormat
and selectTrim
.
data:image/s3,"s3://crabby-images/c72e6/c72e6e12e389712a8c44c278cca61a137de31806" alt="Trim Text"
Remove Duplicates
From the Home
ribbon, select Remove Rows
and click Remove Duplicates
.
data:image/s3,"s3://crabby-images/3afd1/3afd12a784fb7c6eb65f8285a596554a49d05e73" alt="Remove Duplicates"
Relating Tables
Next, we need to create a relationship between TBL_INVENTORY
and the newly created TBL_CONTACTS
table.
data:image/s3,"s3://crabby-images/8804d/8804d054c2cf6f34dabaf53c8937225178703199" alt="Model View"
- In Power BI, switch to the
Model view
. - Create a relationship between
TBL_INVENTORY
andTBL_CONTACTS
by dragging theContacts
field inTBL_INVENTORY
to theContacts
field inTBL_CONTACTS
. - The
New relationship
dialog box is displayed. - Set the
Cardinality
toMany to many (*:*)
withCross-filter direction
set toBoth
. - Enable the
Make this relationship active
checkbox. - Click the
Save
button.
data:image/s3,"s3://crabby-images/3ac8b/3ac8b357a1f3dc13cee880db086d639d72ca4f3a" alt="New Relationship Configuration"
Add Visualizations and Slicers
Finally, let’s build the report by adding a table visualization and slicer:
- In Power BI, switch to
Report view
. - Add a
Table
visualization. - From
TBL_INVENTORY
, configure the table visualization by addingAsset
andContacts
toColumns
.
data:image/s3,"s3://crabby-images/b7aee/b7aee511d13e0e4a16a5ec60320504b0f2135800" alt="Table Visualization Configuration"
- Add a
Slicer
. - From
TBL_CONTACTS
, configure the slicer by addingContacts - Copy
toField
.
data:image/s3,"s3://crabby-images/473fb/473fbafb4b8205f8064165e13ef3c327735d0a0b" alt="Non-delimited Slicer Configuration"
Results
In the screenshot below, the slicer on the right is based on individual contact names. Selecting “Clark, Ethan” filters the table correctly, displaying all entries associated with him, including those where he is a co-owner.
data:image/s3,"s3://crabby-images/d1354/d1354eb30916223f7aaf2139ba95a937698210bf" alt="Expected Result"
Summary
In this article, we created a slicer based on a delimited data column, allowing users to filter individual contact names easily. By preparing the slicer data and relating tables, we ensured that selecting a name in the slicer displayed all relevant assets, even those with co-ownership. This approach simplifies filtering and enhances the usability of asset inventory data in Power BI.