ARRAY TO COLLECTION
ARRAY TO COLLECTION ( collection ; array {; propertyName}{; array2 ; propertyName2 ; ... ; arrayN ; propertyNameN} )
Parameter | Type | Description | |
---|---|---|---|
collection | Collection | ← | Collection to receive the array data |
array | Array | → | Array to copy to the collection; if propertyName passed, array to copy to the values of propertyName in the collection |
propertyName | Text | → | Object property name whose value to fill with array elements |
Description
The ARRAY TO COLLECTION command copies one or more array(s) into the elements or the propertyName values of collection.
This command can work with a collection that contains values or a collection that contains objects, in which case the propertyName parameter(s) are mandatory.
- If you omit the propertyName parameter, the command copies all array elements to collection. If collection was not empty, existing elements are replaced and new elements are added if the size of array was larger than the collection length. After the command is executed, the collection length is identical to the size of array.
- If you pass one or more propertyName(s) parameters, the command creates or replaces elements of collection as objects. Each object is filled with a property whose name is provided in the propertyName parameter, and whose value is the corresponding array element. If collection was not empty, existing elements are replaced and new elements are added if the size of array was larger than the collection. After the command is executed, the collection length is the same as the size of the largest array.
Example 1
You want to copy a text array in a collection:
var $colFruits : Collection
$colFruits:=New collection
ARRAY TEXT($artFruits;4)
$artFruits{1}:="Orange"
$artFruits{2}:="Banana"
$artFruits{3}:="Apple"
$artFruits{4}:="Grape"
ARRAY TO COLLECTION($colFruits;$artFruits)
//$colFruits[0]="Orange"
//$colFruits[1]="Banana"
//...
Example 2
You want to copy field values in a collection of objects through arrays:
var $col : Collection
$col:=New collection
ARRAY TEXT($artCity;0)
ARRAY LONGINT($arLZipCode;0)
SELECTION TO ARRAY([Customer]City;$artCity)
SELECTION TO ARRAY([Customer]Zipcode;$arLZipCode)
ARRAY TO COLLECTION($col;$artCity;"cityName";$arLZipCode;"Zip")
//$col[0]={"cityName":"Cleveland","Zip":35049}
//$col[1]={"cityName":"Blountsville","Zip":35031}
//...
Example 3
You want to copy a text array in a shared collection:
ARRAY TEXT($at;1)
APPEND TO ARRAY($at;"Apple")
APPEND TO ARRAY($at;"Orange")
APPEND TO ARRAY($at;"Grape")
var $sharedCol : Collection
$sharedCol:=New shared collection
Use($sharedCol)
ARRAY TO COLLECTION($sharedCol;$at)
End use
See also
COLLECTION TO ARRAY
Type conversions between collections and 4D arrays
Properties
Command number | 1563 |
Thread safe | ✓ |