0

How can I add two arrays?

Any idea how you can add arrays in NINOX

let a := 1;
let b := 2;
let c := 3;
let d := 4;
let ar1 := [a, b, c];
let ar2 := [d];
let ar3 := [ar1 + ar2];
ar3

This will give the result 1234 instead of 1,2,3,4

Thanks

23 replies

null
    • Nick
    • 5 yrs ago
    • Reported - view
    • Ninox partner
    • RoSoft_Steven.1
    • 5 yrs ago
    • Reported - view

    With concat() ?

    • Sean
    • 5 yrs ago
    • Reported - view

    I'm not sure why the Ninox team made array manipulation so difficult. It's like they wanted arrays to be read-only after the arrays are defined. One way is to break the arrays down and then rebuild them like this...

     

    let a := 1;
    let b := 2;
    let c := 3;
    let d := 4;
    let ar1 := [a, b, c];
    let ar2 := [d];
    let ar3 := concat(ar1) + ", " + concat(ar2);
    let ar4 := split(replace(ar3, ", ", ","), ",")

     

    You can combine the lines for ar3 and ar4, but I separated them so it would be easier to see what's going on.

    • Sean
    • 5 yrs ago
    • Reported - view

    Nice timing Steven :)

     

    One of the problems with this approach is now your array values are text instead of number and if you want to do any arithmetic with the values you will have to convert them to number type like...

     

    number(item(ar4, 1))

    • Ioannis
    • 5 yrs ago
    • Reported - view

    thank you  Sean

     i guess it would be very complicated to have as a result an array of numbers then ?

    • Jorg
    • 5 yrs ago
    • Reported - view

    Hi, 

    In order tp get an array as a result you can use the function unique():

     

    myMultipleChoiceField := unique(numbers(ar2), 2, 7)

    Best, Jörg

    • Sean
    • 5 yrs ago
    • Reported - view

    @Ioannis, it's possible and once you have the code worked out it will do all the work for you. Post what you want to do and I will try to help.

     

    @Jörg, that just returns the values that are not of type array, ie, 2 & 7.

    • Jorg
    • 5 yrs ago
    • Reported - view

    Hi Sean, 

    if the ar2 in my example is an array of numbers (I just took it form your example), the formula should give back an array with all unique numbers.

    Best, Jörg

    • Sean
    • 5 yrs ago
    • Reported - view

    Hi Jörg,

    numbers() is not a function in the Mac app. Here is a screenshot of my test...

     

    Screen Shot 2019-03-13 at 9.54.41 AM

    • Jorg
    • 5 yrs ago
    • Reported - view

    Hi Sean, 

    numbers() works only to get an array out of a Multiple choice field. 

    The formla according your example should be:

     

    let a1 := [3,5];
    let a2 := unique(arr1,2)

     

    Sorry, for the confusion.

    Best, Jörg

    • Sean
    • 5 yrs ago
    • Reported - view

    Hi Jörg,

    Thank you for posting this. The array request has been going on for some time now... is this recently implemented functionality?

     

    Best, Sean

    • Ioannis
    • 5 yrs ago
    • Reported - view

    Hi Sean Thank you for the help

    No it is not a new feature but one that is not well documented in the manual

    So another question 

    How can a make an array from the string

    Zhu Ling, Fu Ling, Che Qian Zi, Ze Xie, Yin Chen, Chi Shao, Mu Dan Pi, Huang Bai, Zhi Zi, Niu Xi

    • Ioannis
    • 5 yrs ago
    • Reported - view

    I thing i got that 

    let x := split("Zhu Ling, Fu Ling, Che Qian Zi, Ze Xie, Yin Chen, Chi Shao, Mu Dan Pi, Huang Bai, Zhi Zi, Niu Xi", ",")
    item (x,1)

    • Sean
    • 5 yrs ago
    • Reported - view

    Ioannis You’re welcome. Looks like you’ve got it.

     

     I’m familiar with the unique() function’s named purpose, but was not aware that it would combine an array with other values. The topic of arrays has gone on for several months now and this is the first time I’ve seen this solution.

    • Ioannis
    • 5 yrs ago
    • Reported - view

    Hi Sean

    I managed to solve the problem of adding two string arrays 

    I am stuck though in trying to add two numeric arrays

    let a := 1;
    let b := 2;
    let c := 3;
    let d := 4;
    let ar1 := [a, b, c];
    let ar2 := [d];
    let ar3 := [concat(ar1) + ", " + concat(ar2)];
    'Multiple choice' := ar3

    I tried a lot of different combinations and always get the error

    • Sean
    • 5 yrs ago
    • Reported - view

    Hi Ioannis

    That is one of the problems with those array functions at the moment... they always return text values regardless of the input type. Another problem is any value/item that has a "," in it (ie, "Acme, Inc") will cause the value to be split at that point because you can't choose the concatenating character in the concat() function; strange considering you have to choose the splitting character in the split() function.

     

    Jörg's solution using unique() works well as long as you don't need to duplicate items in your array. It solves the number value issue as well as the "," issue.

    • Sean
    • 5 yrs ago
    • Reported - view

    Ioannis

    Sorry, I got two threads mixed up in my head. In your example ar3 becomes an array with a single item equal to "1, 2, 3, 4". You can test this with item(ar3, 0). If you use any other index you will get null as the return value because there is now only one item in the array

    • Ioannis
    • 5 yrs ago
    • Reported - view

    No problem Sean

    I dug a little and found a solution

     

    let array := numbers('Multiple choice');
    let max := cnt(array) + 1;
    let add := 10;
    var newArray := for ind from 0 to max do
    if ind = max - 1 then add else item(array, ind) end
    end;
    'Multiple choice' := newArray

    With this formula you can read the existing array from a multiple choice field, add one more and write it back to the same field

    i post this for someone that maybe will need

    • Sean
    • 5 yrs ago
    • Reported - view

    Yes, I'm familiar with that thread. I'm curious why you would choose that approach instead of one like this...

     

    let array := numbers('Multiple choice');
    let add := 10;
    array := unique(array, add)

     

    Do you have duplicate values?

    • Sean
    • 5 yrs ago
    • Reported - view

    I just noticed that it could have reduced it to 2 lines...

     

    let array := numbers('Multiple choice');
    array := unique(array, 10)

     

    You can also use it with slice() to insert items...

     

    let myArray := [1,2,3,4,7,8,9];
    myArray := unique(slice(myArray, 0, 4), 5, 6, slice(myArray, 4, 7))

     

    The second index position of the slice() function is not inclusive.

    • Ioannis
    • 5 yrs ago
    • Reported - view

    Hi Sean 

    Thanks a million

    The first one works perfectly!!!

    And it is very simple!!!

    • Johannes_Faller
    • 3 yrs ago
    • Reported - view

    works, but I can't find a documentary about it

     

    let mA := ["A", "B", "C"];
    let mB := ["X", "Y", "Z"];
    let mC := array(mA, mB);
    concat(mC)

    • Sean
    • 3 yrs ago
    • Reported - view

    Johannes, you can find the information here...

     

    https://ninox.com/en/manual/calculations/reference-of-functions-and-language