Pivoting Text Data
Overview
Here we explain a technique for pivoting non-numeric text data.
Pivoting Text Data
Often data needs to be transformed into a particular ‘shape’ before it can be used for further analysis, such as in the tables below, where the table on the left-hand side needs to be transformed into one that looks like the one on the right-hand side.
In the left-hand side table, column A contains the attribute, and B the values, and every 4 lines of data is a record. This kind of transformation problem is very common with older systems, when you cannot change the format of the extracted data.
data:image/s3,"s3://crabby-images/2ad07/2ad073cd06db0f28b9ae8330054dce09824a4e64" alt=""
You cannot pivot Text Data directly
This is NOT how to do it. If you click on Column A above, in Power Query, and select ‘Pivot Column’, you will get the following results:
data:image/s3,"s3://crabby-images/b378c/b378cfac2f6ea3d297441bce703421d1bd85dc29" alt=""
This approach won’t work, because Power Query does not know how to uniquely identify each record set.
Steps
In the data above, every 4 consecutive rows represents a record. So you need to assign every 4 rows with a next ID number. This unique ID number can then be used, to pivot the data on, to produce the desired results.
1. Add an Index Column
- Click anywhere in the Table ➔ go to the Data tab (in Excel) ➔ click the From Table / Range icon.
In the Query Editor, add a new Index Column.
- Go to the ‘Add Column’ tab ➔ click the ‘Index Column’ icon
- Choose to add the ‘Index Column’ starting from ‘0’
data:image/s3,"s3://crabby-images/8e31e/8e31e7a2de65abed1341cb213aa5168ccd6853a1" alt=""
2. Divide the Index column by 4
- Click on the Index column ➔ go to the ‘Transform’ tab ➔ click on the ‘Standard’ icon
data:image/s3,"s3://crabby-images/0a44f/0a44fd28762555c7e9aa4258d21ab90b7bf6069a" alt=""
- Choose to divide by 4 ➔ click OK
data:image/s3,"s3://crabby-images/0caca/0caca75756c0caf1caea947116716a7c2ee3051f" alt=""
The index column should now look as follows:
data:image/s3,"s3://crabby-images/bba30/bba301636dfb38da387342064a67377a74a3a589" alt=""
3. Pivot the Data
Now, the data is ready to be pivoted
- Select Column 1 ➔ click the ‘Pivot Column’ icon under the ‘Transform’ tab
- Choose Column 2 as the Values column
- Under Advanced options, choose ‘Don’t Aggregate’
data:image/s3,"s3://crabby-images/8bf1c/8bf1c0193e110042e2b3961cf7163c77ec6502aa" alt=""
The data will now pivot properly, and look as follows:
data:image/s3,"s3://crabby-images/ba8ea/ba8eac6bd99c36ca39ce9e771b56dc832096d2be" alt=""
4. Load the data to Excel
- Finally, remove the Index column as it is now no longer needed
- Close and Load the query to Excel
After some formatting, you should have a table that looks like this, showing the data in the desired layout!
data:image/s3,"s3://crabby-images/012cd/012cdd793a7bd9c14ba443149a9039a562b42424" alt=""
Feedback
Submit and view feedback