Power BI – Import Text Using Examples
Import text using examples was introduced in the 2020 August update for Power BI. It writes the Power Query steps to transform a non-tabular text file into a table.
data:image/s3,"s3://crabby-images/0ba4a/0ba4ad4c516fb42d0e96aae12a552bb6fdc64261" alt="from import to table"
YouTube Version
Enabling the Feature
At the point of writing this blog post this feature is still in preview. The feature is enabled in File – Options in Preview features. It will like most features move to being enabled for everyone at some point.
data:image/s3,"s3://crabby-images/03d2a/03d2a3eccc1985f25d5e1a70bd59720aa4f91949" alt="Enable import text using examples feature"
Example Import text using Examples
For this example I have a very simple text file as shown in first picture in this post. It contains the details of journeys on different days. So when I select Get Data – Text/CSV and select the file, the dialog that shows a preview of the data in the file has a new button.
data:image/s3,"s3://crabby-images/d0583/d0583b5c1454790957e4a26d12ff6393e70113d8" alt="Showing Extract Table Using Examples button"
When the button is clicked a new dialog opens a dialog box with a data preview showing and an empty table. This means we need to enter in some answers into the table so a pattern can be calculated how to transform the data. When you start to type in a value it will suggest possible values.
A column is renamed by double clicking on the column title and entering a new name.
data:image/s3,"s3://crabby-images/8d0de/8d0def75f8877f4a6f5f87ca5f4d27cfc502430f" alt="entering first column into import text file using example"
With only one value it cannot calculate the pattern required. When I have added more values it can determine the pattern. It often needs less values in future columns. In this example 2 dates were needed for the first column and then only one value for the remaining columns.
data:image/s3,"s3://crabby-images/2a5dd/2a5dd493ac83d6f17ecd0b2f8a80d6f248f09896" alt="showing stages of adding example values in"
In the above example the Distance column was only part of the row of data. It calculates the ways to split the data. After this and all the columns have been added, we click Transform Data to see the Power Query steps that the import feature have been written.
Looking at the Power Query
So the magic behind this new feature is it writes a 10+ step query for you with a pretty good pattern for doing this. So the 5 steps after the source are working out how many rows make a block of data and grouping that data into one block. The next chunk of steps are splitting that block into separate columns.
data:image/s3,"s3://crabby-images/5d3e0/5d3e09308ca465dd19f19a82be35fd82f1b7472c" alt="look at the power query created by import text by using examples"
How does import text using example decide the block length?
This for me is the clever part. Step three where it adds the conditional column is the crucial step. So I looked at three slightly different versions of the text file to see how it changes.
Example 1
data:image/s3,"s3://crabby-images/25da3/25da3362bbb8cb46ccb7277d8f0039f32df0f1ea" alt="step 3 when starting with a date"
In this example each of the blocks start with a date, which means the line starts with a number. Step 3 uses a test to see if in position 0 there is a number. So for this example, we could have as many rows as we liked in a block as long as the first row is the only row starting with a number.
Example 2
data:image/s3,"s3://crabby-images/9e41f/9e41f104e0927c29998c0b778c0729a99c2932f6" alt="example 2 starting with the word date."
In this example the blocks start with the word “Date”. Step 3 looks for the line starting with “Date” as the first line. This is pattern is a great one as it works fine for different length blocks as long as the only lines starting with “Date”.
Example 3
data:image/s3,"s3://crabby-images/abd82/abd82bedcaebd37081a173c7b4dcce7465e1ac2e" alt="example 3 when there is no obvious pattern"
In this example there is no easy way to identify the top row of the data. This means the only pattern it can determine is by length of the block so it guesses 4. This works if the data is in same length blocks.
Conclusion
I like the new import text using examples feature and I can see places where it will get used. I hope it gets progressed to recognise more patterns and be more flexible. When it works it stops the report writer needing to put together the Power Query steps to do the transform.
More Power BI Posts
- Conditional Formatting Update
- Data Refresh Date
- Using Inactive Relationships in a Measure
- DAX CrossFilter Function
- COALESCE Function to Remove Blanks
- Personalize Visuals
- Gradient Legends
- Endorse a Dataset as Promoted or Certified
- Q&A Synonyms Update
- Import Text Using Examples
- Paginated Report Resources
- Refreshing Datasets Automatically with Power BI Dataflows
- Charticulator
- Dataverse Connector – July 2022 Update
- Dataverse Choice Columns
- Switch Dataverse Tenancy
- Connecting to Google Analytics
- Take Over a Dataset
- Export Data from Power BI Visuals
- Embed a Paginated Report
- Using SQL on Dataverse for Power BI
- Power Platform Solution and Power BI Series
- Creating a Custom Smart Narrative
- Power Automate Button in a Power BI Report
Glad you enjoyed it.