dict
Syntax
dict(keyObj, valueObj, [ordered=false])
or
dict(keyType, valueType, [ordered=false])
Arguments
For the first usage:
keyObj is a vector indicating dictionary keys.
valueObj is a vector indicating dictionary values.
For the second usage:
keyType is the data type of dictionary keys. The following data categories are supported: Integral (excluding COMPRESSED), Temporal, Floating and Literal.
valueType is the data type of dictionary values. Note that COMPLEX/POINT is not supported.
ordered (optional) is a Boolean value. The default value is false, which indicates to create a regular dictionary. True means to create an ordered dictionary. The regular dictionaries do not track the insertion order of the key-value pairs whereas the ordered dictionaries preserve the insertion order of key-value pairs.
Details
Return a dictionary object.
Examples
x=1 2 3
y=4.5 7.8 4.3
z=dict(x,y);
z;
/* output
3->4.3
1->4.5
2->7.8
*/
z=dict(INT,DOUBLE);
z[5]=7.9;
z;
// output: 5->7.9
z[3]=6;
z;
/* output
3->6
5->7.9
*/
dt=dict([`test], [1]);
dt;
// output: test->1
//create an ordered dictionary
z=dict(x,y,true)
z;
/* ouput
1->4.5
2->7.8
3->4.3
*/
// y is a vector of DECIMAL32 type. Create an ordered dictionary z with y as values.
x=1 3 2
y = decimal32(1.23 3 3.14, 3)
z=dict(x,y,true);
z;
/* output
1->1.230
3->3.000
2->3.140
*/
To get keys and values of a dictionary:
x=1 2 3
y=4.5 7.8 4.3
z=dict(x,y);
z.keys();
// output: [3,1,2]
z.values();
// output: [4.3,4.5,7.8]
related system functions: array, matrix, dictUpdate!, syncDict