Thursday, 20 February 2014

String Functions: Part 1




In this series, I will be exploring string functions. QlikView has an abundance of functions available at your disposal to manipulate and parse what is presented in the final data model. This series will be focusing on string functions used during the load process.

The series will explore the following string functions and their uses

  • Left(), Right() and Mid()
  • Index()
  • Subfield()
  • KeepChar() and PurgeChar()
  • FirstSortedValue() and Min()
  • TextBetween()
  • Replace()
  • FindOneOf()
  • SubStringCount()

Part 1: Left(), Right(), Mid() and Index()

I am confident that every QlikView developer has used the above function in some way or another. Firstly, lets explore their use in a non-nested way

Left/Right(Text,Count) - Takes the input text whether a literal string or an expression and from the left or right side, returns the characters for that length. There are many situations where this is useful. One common use is when a field contains a value that can be described as the sub type and you want to extract this out















Even though the functions Replace() and PurgeChar() will be discussed in more detail in a later series; I wanted to illustrate how they can be used in conjunction with Left()/Right() to display certain values. The user can now select an ID category and then an ID number to further drill down and isolate

Mid()/Index() are very powerful functions, especially when used together. Mid(Text,Start,Count) is a 3 parameter function. The difference to left and mid is that you can specify where to start from. This adds a nice dynamic when used in conjunction with Index. Index(Text,Substring,Count) returns the starting position of a string within a string. Lets look at the following example which will illustrate how these 2 functions operate















Once again, for illustration I have used a function to be discussed later i.e. FindOneOf(). But as before, this is to demonstrate the versatility of the mid function in conjunction with any other string parsing expression.

My expression Mid(ID,Index(Upper(ID),'H',1),3) as HATSubType returned the value HAT for whenever that instance occurred. I used Upper() to ensure that the string I was matching to would be found, this is because the string to match is case sensitive. The output to the load above is








Essentially, 1 of 2 things need to be present when applying transformation to your data.
  1. Does a pattern or set sequence exist - In the above examples, the subtype was always 3 characters long. Where it started did not matter now, what did was finding it. Since I knew the preceding character would be numeric, it was easy to find the starting position of my ID SubType
  2. Is there a common delimiter - In the following example '011-254-7398', there is a '-' between each part in the above phone number. Since this will occur for all phone numbers, we can use Index(PhoneNumber,'-',which instance to use) to isolate the starting position of the characters we do want
I hope you enjoyed this part of the series and if you have any suggestions on what I should discuss next, please let me know

Until next time, cheers!

Tuesday, 18 February 2014

User Defined Measurements


Let's imagine this is your situation; you go to a client meeting where there is an initial scoping session for a proposed QlikView dashboard solution. You quickly identify that the client has preconceptions of what is possible from a reporting perspective and so has defined his charts and visuals based on what he is aware of. You also gauge through follow-up sessions that each of the functional heads for the different LOB want to see something slightly different.

One of the hardest challenges when designing a dashboard is deciding what charts to use and the layout to address all of the stakeholders requirements. One feature that I really like is dollar-sign expansions $(=string/variable). With some careful planning in your script, you are now able to allow your users to define their charting based on their requirements. 


This is a 5 stage approach


1) Name and define expression variable in script







2) Create an INLINE LOAD with the variable name and alias this variable through another column




3) Create Input boxes that will house your variable list - My expression in the listed values selection is ','&concat(DISTINCT AgentMeasureName,','). I also created an input box that will house my dimensions that I want the user to aggregate by. The values are simply a delimited list i.e. Calendar Date;Calendar Week;Calendar Month;Calendar Week Day;Team Leader;Manager;Shift











4) Create a bar chart with a dimension and expression that allows for dynamic reporting















The dimension I used was the following: 












I like my users to see a narrative that is clean and easy to read, hence the string match and what dimension to use. What's very important is that the variable that contains the drop down be used to match against and pick the relevant field to act as the dimension

5) Expression






What's great about this expression is that it will dynamically select the expression you defined in your script based on the selections users make on the front-end. The FieldValue(FieldIndex()) returns a string that contains the script variable name i.e. vAgentCallsAnswered. Since this is defined in our let statement, using a dollar sign expansion = $(vAgentCallsAnswered) returns our expression i.e. num(sum(AgentCallsAnswered)). The next dollar sign expansion then forces this to calculate and thus render the chart with the correct output based on selections made.

This approach can have many uses. One of my other favourite is for comments. No longer do i need to have a separate tab with a show/hide event to populate comments as text boxes. I can now have 1 text box in my main sheet and call the comment based values chosen by the EU.
Welcome to QlikVieW Ramblings!


As you might of guessed, this blog is mainly dedicated to QlikView. I will be posting interesting uses of functions and expressions and what I deem to be best practise given a particular situation.

The ramblings part is anything I feel is worth-while sharing. Whether it be around how we can be more giving in our daily lives / philanthropy, or some really cool visual techniques and mathematical algorithms. 

So who am I and what do I intend to achieve with this blog


I am a QlikView Consultant specialising in, guess what, QlikView :)solutions. I am a strong advocate of the product and believe that QlikView has changed the way we as consumers interact and visualise our data. It has also empowered anyone in the organisation to take charge and understand the drivers in their business. Allowing anyone to be a decision enabler to the decision makers.

Image Above: QlikView Open Data Challenge Winning Dashboard

The QlikCommunity Website is a great repository of feedback from experienced developers and urge all to go and register and participate in the discussions. This blog will have snippets of use cases around the most commonly used functions and expressions. I look forward to hearing your feedback on my posts and will always endeavour to address each and every question.

Happy Qliking and lets enjoy this journey of discovery together


Byron Van Wyk
QlikView Consultant