Sample code for 30+ languages & platforms
Delphi DLL

Merge SP-API JSON Order Arrays

See more Amazon SP-API Examples

Demonstrates how to merge JSON arrays for the case of Amazon SP-API orders.

Chilkat Delphi DLL Downloads

Delphi DLL
uses
    Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants, System.Classes, Vcl.Graphics,
    Vcl.Controls, Vcl.Forms, Vcl.Dialogs, Vcl.StdCtrls, JsonArray, JsonObject;

...

procedure TForm1.Button1Click(Sender: TObject);
var
success: Boolean;
a1: PWideChar;
a2: PWideChar;
json1: HCkJsonObject;
json2: HCkJsonObject;
jarr1: HCkJsonArray;
jarr2: HCkJsonArray;
i: Integer;
numOrders: Integer;
jOrder: HCkJsonObject;

begin
success := False;

// Batch 1 File
a1 := '{"payload": {"Orders": [{"AmazonOrderId": "1","OrderStatus": "Unshipped"},{"AmazonOrderId": "2","OrderStatus": "Unshipped"}]}';

// Batch 2 File
a2 := '{"payload": {"Orders": [{"AmazonOrderId": "3","OrderStatus": "Unshipped"},{"AmazonOrderId": "4","OrderStatus": "Unshipped"}]}';

// Required Merged File
// {"payload": {"Orders": [{"AmazonOrderId": "1","OrderStatus": "Unshipped"},{"AmazonOrderId": "2","OrderStatus": "Unshipped"},{"AmazonOrderId": "3","OrderStatus": "Unshipped"},{"AmazonOrderId": "4","OrderStatus": "Unshipped"}]}

success := True;
json1 := CkJsonObject_Create();
CkJsonObject_Load(json1,a1);

json2 := CkJsonObject_Create();
CkJsonObject_Load(json2,a2);

// We're going to add the order records from json2 to json1.
jarr1 := CkJsonObject_ArrayOf(json1,'payload.Orders');
jarr2 := CkJsonObject_ArrayOf(json2,'payload.Orders');

i := 0;
numOrders := CkJsonArray_getSize(jarr2);
while (i < numOrders) do
  begin
    jOrder := CkJsonArray_ObjectAt(jarr2,i);
    // Assuming non-null return...
    CkJsonArray_AddObjectCopyAt(jarr1,-1,jOrder);
    i := i + 1;
  end;

// Show the merged JSON.
CkJsonObject_putEmitCompact(json1,False);
Memo1.Lines.Add(CkJsonObject__emit(json1));

// Result:

// {
//   "payload": {
//     "Orders": [
//       {
//         "AmazonOrderId": "1",
//         "OrderStatus": "Unshipped"
//       },
//       {
//         "AmazonOrderId": "2",
//         "OrderStatus": "Unshipped"
//       },
//       {
//         "AmazonOrderId": "3",
//         "OrderStatus": "Unshipped"
//       },
//       {
//         "AmazonOrderId": "4",
//         "OrderStatus": "Unshipped"
//       }
//     ]
//   }
// }

CkJsonObject_Dispose(json1);
CkJsonObject_Dispose(json2);

end;