Data Types Cheat Sheet
Base Data Types
String
DECLARE
UiPath | strMyVar (String) Default is Null (Nothing) |
VB | Dim strMyVar As String |
C# | string strMyVar; |
ASSIGN
strMyVar = “double quotes are needed”
COOL STUFF
String.IsNullOrEmpty(strMyVar) => test for if not initialized
strMyVar + ” and another string” => concatenation
String.Format(“{0} is {1}”, strVar1, strVar2) => interpolation
Split(strMyVar, ” “) => returns array – second arg is delim
strMyVar.Replace(vbcr, ” “).Replace(vblf, ” “) => strips carriage returns
strMyVar.IndexOf(“searchFor“) => returns integer position where 1st found
strMyVar.IndexOf(“searchFor“, startpos, countOfLettersToSearch) => to limit search
strMyVar.Substring(startPos, length) => return an embedded string
Left(strMyVar, numChars) => return left (or right) side of string
Trim(strMyVar) => trims whitespace both sides – also RTrim and LTrim
String.Join(“,”, arrVarName) => joins from Array into string with separator
String.Split(” “, arrVarName) => Splits string into Array of substrings at separator
Boolean
DECLARE
UiPath | boolMyVar (Boolean) Default is False |
VB | Dim boolMyVar As Boolean |
C# | bool boolMyVar; |
ASSIGN
boolMyVar = True
boolMyVar = (1 + 2 = 3)
Int32
DECLARE
UiPath | intMyVar (Int32) Default is 0 |
VB | Dim intMyVar As Integer |
C# | int intMyVar; |
ASSIGN
intMyVar = 123
intMyVar = 123.45 Not allowed
CONVERT
CInt(strNumericVal) => ex: “2” (“2.5” will be rounded to 3)
Double
DECLARE
UiPath | dblMyVar (System.Double) Default is 0 |
VB | Dim dblMyVar As Double OR Dim dblMyVar# |
C# | double dblMyVar; |
ASSIGN
dblMyVar = 123.45
CONVERT
boolSuccess = Double.TryParse(strValue, 0) => test if can parse
dblMyVar = CDbl(strValue) => parse
dblMyVar = Double.Parse(strValue) => parse
COOL STUFF
strMyVar = dblMyVar.ToString(“F2”) => prints with 2 decimals (rounded)
Math.Round(dblMyVar, x) => rounds to x digits
DateTime
DECLARE
UiPath | dteMyVar (System.DateTime or System.DateOnly) Default is 01/01/0001 00:00:00 (Internally stored as number need to format as a string to get month day year etc) |
VB | Dim dteMyVar As DateTime |
C# | DateTime dteMyVar; |
ASSIGN
dteMyVar = new DateTime(2020, 02, 12, 2, 35, 07) => (year, month, day, hour, minute, second) – time always defaults to 00:00:00 midnight unless specified
dteMyVar = DateTime.Now OR Date.Now => for timestamps
dteMyVar = DateTime.Today OR Date.Today => default time will be midnight
dteMyVar = CDate(“01/05/1960”)
formatting symbols
Example: January 5, 2001 at 2:06:07 PM
- yyyy – 2001
- yy – 01
- y – 1
- MMMM – January
- MMM – Jan
- MM – 01
- M -1
- dddd – Friday
- ddd – Fri
- dd – 05
- d – 5
- HH – 14
- H – 14
- hh – 02
- h – 2
- mm – 06
- m – 6
- ss – 07
- s – 7
- tt – PM
- For more click here
Format any DateTime by using pattern made from symbols listed above
dteMyVar.ToString(“MM/dd/yy”) => 01/05/01
COOL STUFF
Date.ParseExact(strDate, “dd-MM-yyyy”, System.Globalization.DateTimeFormatInfo.InvariantInfo)
=> to convert date string into DateTime by local formatting (make pattern what input is)
dteMyVar.AddDays(x) => x days from date, can do negatives to go backwards
Structured Data Types
Array
IMPORTANT! It’s not easy to add elements to array at runtime. Use List for dynamic arrays.
DECLARE
UiPath | arrMyVar (Array of [T]) Default is Null (Nothing) |
VB | Dim arrMyVar(20) As Integer OR Dim arrMyVar(0 To 20) As Integer => creates array with 21 spots for whatever data type |
C# | int[] arrMyVar; |
INITIALIZE
arrMyVar = New Integer(){} => will need to init with elements later
arrMyVar = New Integer(10){} => with 11 places
arrMyVar = New Integer(){1,2,3} => init with elements
ASSIGN
arrMyVar = {1, 2, 3} => entire array
arrMyVar(2) = 5 => specific element (must be inbounds)
COOL STUFF
arrMyVar.Length => how many places
arrMyVar(0) => get specific element (0-based)
USEFUL ACTIVITIES
For Each => iteration
List
declare
UiPath | lstMyVar (List<T> from System.Collections.Generic) Default is Null (Nothing) |
VB | Dim lstMyVar As New List(Of Integer) |
C# | List<Integer> lstMyVar; |
INITIALIZE
(be sure to initialize at Variables panel) New List(Of whatever)
lstMyVar = New List(Of Integer) => count is now 0
lstMyVar = New List(Of Integer) From {1,2,3,4,5} => init and assign
useful activities
- Build Collection
- Create List
- Append Item To List
- Update List
- Read List Item
- For Each
- Collection to Data Table
COOL STUFF
lstMyVar.Count => how many elements
lstMyVar.Item(0) => get specific element (0-based)
lstMyVar.GetRange(0,3) => gets first 3 items in list — returns a new list
Enumerable.Concat(1stList, 2ndList).ToList => join two lists together
String.Join(“,”, lstMyVar) => all elements into string for printing
Dictionary
declare
UiPath | dicMyVar (Dictionary<TKey, TValue> from System.Collections.Generic) Default is Null (Nothing) |
VB | Dim dicMyVal As New Dictionary(Of String, Integer) |
C# | IDictionary<int, string> dicMyVar; |
INITIALIZE
dicMyVar = New Dictionary(Of Integer, String) => count is now 0 (can be used to clear)
dicMyVar = New Dictionary(Of Integer, String) From {{1, “val1”}, {2, “val2”}} => init and assign
assign
dicMyVar(keyname) = whatever => will overwrite if key already there else will add
useful activities
- For Each => key in dicMyVar.Keys (arg type same as key type) then to get value dicMyVar(key)
COOL STUFF
dicMyVar.Count => how many elements
dicMyVar(keyname) => get value by key
dicMyVar.Keys => array of keynames (useful to loop through)
dicMyVar.Values => array of values
boolKeyExists = dicMyVar.ContainsKey(keyname)
boolValExists = dicMyVar.ContainsValue(value)
boolWasRemoved = dicMyVar.Remove(keyname)
dict = dict.Concat(New Dictionary(Of String,Int32)From{{“Teacher”,3},{“Doctor”,3}}).ToDictionary(Function(kv) kv.Key,Function(kv) kv.Value)
=> Concat a second dictionary to first
dict2 = dict1.ToDictionary(Function(kv) kv.Key,Function(kv) kv.Value.Copy) => deep copy one dict into another
Data Table
declare
UiPath | dtMyVar (DataTable from System.Data) Default is Null (Nothing) |
VB | Dim dtMyVar As new DataTable() |
C# | DataTable dtMyVar = new DataTable(); |
INITIALIZE
dtMyVar = New DataTable()
dtMyVar.Columns.Add(“ColumnName”, GetType(System.String)) => assign to Object data type
useful activities
- Read Range Workbook => save to data table variable Properties > Data Table
- Build Data Table => wizard to build columns/values put variable name in Properties > Output
- Add Data Column
- Add Data Row
- Clear Data Table
- Sort Data Table => specify column
- Filter Data Table
- For Each Row in Data Table => loops through table
- Output Data Table as Text => outputs to string so can log
- Write Data Table To Excel
- Join Data Tables => Uses wizard – joins 2 data table variables on specified common values and rules when data doesn’t match
- Lookup Data Table => Looks up specified value and returns the Row Index if found
- Remove Duplicate Rows
COOL STUFF
dtMyVar.Rowcount => number of rows
dtMyVar.Rows.Count-1 => last row
dtMyVar.Rows(rownum).Item(“ColumnName”) => value in column/row
CurrentRow.Item(“ColumnName”) => value in loop
dtMyVar.Rows.Add(“ColumnName”, 32 ) => add row and data all at once
dtTable.Rows(0)(“ColumnName”).GetType().ToString() => check the data type of a column
‘Loop through data and change data type (Using invoke code)
dtTable.AsEnumerable().ToList().ForEach (
Sub(rs)
rs(“Date”)=CDate(rs(“Date”))
End Sub
)
I highly recommend a package called BalaReva.EasyDataTable.Activities. It makes changing data types of a column much easier. Learn how to use it here.