Early Access: The content on this website is provided for informational purposes only in connection with pre-General Availability Qlik Products. All content is subject to change and is provided without warranty.
Mid() returns the part of the input string starting at the position of the character defined by the second argument, 'start', and returning the number of characters defined by the third argument, 'count'. If 'count' is omitted, the rest of the input string is returned. The first character in the input string is numbered 1.
Syntax:
Mid(text, start[, count])
Return data type: string
Arguments
Argument
Description
text
The original string.
start
Integer defining the position of the first character in text to include.
count
Defines the string length of the output string. If omitted, all characters from the position defined by start are included.
Example: Chart expressions
Example
Result
Mid( 'abcdef',3 )
Returns cdef
Mid( 'abcdef',3, 2 )
Returns cd
Example - Mid fundamentals
Overview
Open the Data load editor and add the load script below to a new tab.
The load script contains:
A dataset which is loaded into a data table called Example.
The following fields in the data table:
InputText, the original text string
StartPosition, the starting position of the first character to include from the original text string after processing
CharacterCount, the number of characters to return (optional parameter)
Load the data and open a sheet. Create a new table and add these fields as dimensions:
InputText
StartPosition
CharacterCount
Create the following calculated dimensions:
=mid(InputText,StartPosition), to calculate the characters to extract from InputText starting at the value in the StartPosition field. The function will return all characters from the StartPosition value to the end of InputString because no Count parameter was provided.
=mid(InputText,StartPosition,CharacterCount), to calculate the characters to extract from InputText starting at the value in the StartPosition field. The value in CharacterCount determines the number of characters returned, starting from the value in the StartPosition field.
Results table
InputText
StartPosition
CharacterCount
Mid(InputText,StartPosition)
Mid(InputText,StartPosition,CharacterCount
abcdef
2
3
bcdef
bcd
abcdef
3
2
cdef
cd
20210714
2
3
10714
107
20210714
3
2
0714
07
The first row returns the value bcdef for the first expression. The expression starts at position 2 and returns all characters because the Count argument is not set. The second expression also starts at position 2 but returns only the characters bcd because the Count argument is 2.
The second row returns the value cdef for the first expression. The expression starts at position 3 and returns all characters because the Count argument is not set. The second expression also starts at position 3 but returns only the characters cd because the Count argument is 2.
The third row returns the value 10714 for the first expression. The expression starts at position 2 and returns all characters because the Count argument is not set. The second expression also starts at position 2 but returns only the characters 107 because the Count argument is 3.
The fourth row returns the value 0714 for the first expression. The expression starts at position 3 and returns all characters because the Count argument is not set. The second expression also starts at position 2 but returns only the characters 07 because the Count argument is 2.
The following code shows how to use the function in a load script.
A data source contains a column called OrderID that uses the following structured format: ORDYYYY-COUNTRYCODE-ORDERNUMBER. To satisfy a reporting requirement, you must extract and present the country code as a separate column.
Open the Data load editor and add the load script below to a new tab.
The load script contains:
A dataset which is loaded into a data table called Orders.