data:image/s3,"s3://crabby-images/f9d7a/f9d7a2a7dc907724a3c6fd55223a805fc457b5fe" alt=""
Today has been a tough one for me at the data school. Our first day using Tableau Prep Builder and we learnt heaps with Carl. Here is a cool tip I picked up today when using the SPLIT() function, for when right-click->split doesn’t do you were hoping for and you want a little more control! This tip applies to both Tableau Desktop and Tableau Prep Builder.
REMINDER: SPLIT(string, delimiter, token number)
- string = the string field you’d like to split
- delimiter = the part of the string to split at
- token number = the part of the string to return, after the delimiter. This can be a positive or negative number. A positive number instructs the function to work left to right, a negative number instructs the function to work right to left.
Use Case in Tableau Prep Builder
I have a column called Branch ID containing strings comprised of two parts: a branch code and a branch name. I want to split this at the hyphen that separates them, giving me the 3 character branch code and the branch name in separate columns. Lets use the SPLIT() function to do this.
data:image/s3,"s3://crabby-images/d5bac/d5bac444ca435f44a337c3406c2a56d1706dab95" alt=""
Create a calculated field to use the split function for the store name field.
data:image/s3,"s3://crabby-images/014b1/014b1f512fc43dd4c5c3964816f4e4ffbb0947eb" alt=""
[Store ID] = Field Name (column header)
“-” = delimiter (split string at the hyphen)
(+)2 = return the second part of the string. (reading left to right)
In the calculated field. The fact that 2 is positive is important because it will return the second part of string reading from left to right
data:image/s3,"s3://crabby-images/63b8b/63b8beece176580af470af90411fa536d59473cd" alt=""
This time lets split using a negative number instead of a positive one. This means we will read from right to left.
data:image/s3,"s3://crabby-images/30a56/30a56e763fc0b371633785ec23d58197a625c10a" alt=""
[Store ID] = Field Name (column header)
“-” = delimiter (where to split)
–2 = return the second part of the string (reading right to left)
data:image/s3,"s3://crabby-images/6ffda/6ffda0c7e476bad97047c2ad700cb6d38fc74e97" alt=""
To conclude. +/- signs tell the SPLIT() function which way to read when looking for the the part to split after the delimiter!