简体   繁体   English

JSONata按数组排序/排序

[英]JSONata sort / order by of an array

I want to order an array. 我想订购一个数组。 The JSONata expression below has an incoming array as follows. 下面的JSONata表达式具有一个传入数组,如下所示。

[{"id":"Air-1a",
  "Controller":"ESP62",
 "Cntr-TaskNo":10,
 "Cntr-GPIO":13,
 "name":"Air",
 "valueName":"Humidity",
 "Sensor":"DHT22",
 (and many other key pairs)}, 
 {next object}, ...]

I then transform the array with the following JSONata expression: 然后,我使用以下JSONata表达式转换数组:

payload.(
        { "Controller" : $.Controller,
          "Cntr-TaskNo": $.CntrDef.TaskNo,
          "Cntr-GPIO"  : $.CntrDef.GPIO,
          "name"       : $.name,
          "valueName"  : $.valueName,
          "Sensor"     : $.Sensor,
          "id"         : $.id
        }
) 

But now I want to - in the same JSONata expression, sort on firstly the Controller, and then the GPIO. 但是现在我想-在相同的JSONata表达式中,首先对Controller进行排序,然后对GPIO进行排序。 To tried with the Controller only first. 仅首先尝试使用Controller。

I tried: 我试过了:

payload.(
        { $sort("Controller",function($l, $r){$l.Controller > $r.Controller}) : $.Controller ,
          "Cntr-TaskNo": $.CntrDef.TaskNo,
          "Cntr-GPIO"  : $.CntrDef.GPIO,
          "name"       : $.name,
          "valueName"  : $.valueName,
          "Sensor"     : $.Sensor,
          "id"         : $.id
        }
) 

As well as trying to add the sort function at the end with the ~> chaining command. 以及尝试使用〜>链接命令在末尾添加sort函数。 I also tried the order-by operator. 我也尝试了按顺序操作。

Could anyone point me in the right direction? 有人能指出我正确的方向吗?

//---------- The new flow with the changed 'ESP62' to '-' that does not work: // ----------将“ ESP62”更改为“-”的新流程无效:

[{"id":"874b0c77.f87418","type":"inject","z":"6f27a311.d135bc","name":"","topic":"","payload":"","payloadType":"date","repeat":"","crontab":"","once":false,"onceDelay":0.1,"x":200,"y":180,"wires":[["8c196590.c20638"]]},{"id":"8c196590.c20638","type":"change","z":"6f27a311.d135bc","name":"Dataset","rules":[{"t":"set","p":"payload","pt":"msg","to":"[{\"id\":\"Air-1a\",\"Controller\":\"ESP62\",\"CntrTaskNo\":10,\"CntrGPIO\":13,\"name\":\"Air\",\"valueName\":\"Humidity\",\"Sensor\":\"DHT22\",\"aaa\":\"111\",\"bbb\":\"222\",\"ccc\":\"333\"},{\"id\":\"Air-2a\",\"Controller\":\"ESP72\",\"CntrTaskNo\":11,\"CntrGPIO\":14,\"name\":\"Air\",\"valueName\":\"Humidity\",\"Sensor\":\"DHT22\",\"aaa\":\"444\",\"bbb\":\"555\",\"ccc\":\"666\"},{\"id\":\"Air-1a\",\"Controller\":\"ESP62\",\"CntrTaskNo\":2,\"CntrGPIO\":9,\"name\":\"Air\",\"valueName\":\"Humidity\",\"Sensor\":\"DHT22\",\"aaa\":\"777\",\"bbb\":\"888\",\"ccc\":\"999\"},{\"id\":\"Air-1a\",\"Controller\":\"-\",\"CntrTaskNo\":10,\"CntrGPIO\":12,\"name\":\"Air\",\"valueName\":\"Humidity\",\"Sensor\":\"DHT22\",\"aaa\":\"777\",\"bbb\":\"888\",\"ccc\":\"999\"}]","tot":"json"}],"action":"","property":"","from":"","to":"","reg":false,"x":360,"y":180,"wires":[["13981162.14e28f"]]},{"id":"c8a256a5.a170c8","type":"debug","z":"6f27a311.d135bc","name":"","active":true,"tosidebar":true,"console":false,"tostatus":false,"complete":"false","x":690,"y":180,"wires":[]},{"id":"13981162.14e28f","type":"change","z":"6f27a311.d135bc","name":"Jsonata $sort","rules":[{"t":"set","p":"payload","pt":"msg","to":"($sort(payload,function($l , $r){$l.Controller > $r.Controller}) ; \t$sort(payload,function($l , $r){$l.CntrGPIO > $r.CntrGPIO}))","tot":"jsonata"}],"action":"","property":"","from":"","to":"","reg":false,"x":520,"y":180,"wires":[["c8a256a5.a170c8"]]}]

I suggest first sorting the dataset and afterward transform the already sorted array of objects. 我建议先对数据集进行排序,然后对已经排序的对象数组进行转换。 The transformation is trivial and you want to know how to sort, so I show below one possible solution. 转换是微不足道的,您想知道如何排序,因此在下面显示一种可能的解决方案。 It uses an expression with two concatenated $sort functions. 它使用带有两个串联的$ sort函数的表达式。

Edited after a better understanding of the requirement. 在对需求有更好的了解之后进行了编辑。

I tested successfully a Node-RED flow using this expression in a change node: 我在变更节点中使用此表达式成功测试了Node-RED流:

($a := $sort(payload,function($l , $r){$l.Controller > $r.Controller}) ; $sort($a,function($l , $r){(($l.Controller = $r.Controller) and ($l.CntrGPIO > $r.CntrGPIO))}))

Flow (contain dataset set hardcoded): 流(包含硬编码的数据集集):

[{"id":"a7814b7e.3adeb8","type":"tab","label":"Flow 4","disabled":false,"info":""},{"id":"8bf10833.c71748","type":"inject","z":"a7814b7e.3adeb8","name":"","topic":"","payload":"","payloadType":"date","repeat":"","crontab":"","once":false,"onceDelay":0.1,"x":140,"y":140,"wires":[["9e365564.edca08"]]},{"id":"9e365564.edca08","type":"change","z":"a7814b7e.3adeb8","name":"Dataset","rules":[{"t":"set","p":"payload","pt":"msg","to":"[{\"id\":\"Air-1a\",\"Controller\":\"ESP62\",\"CntrTaskNo\":10,\"CntrGPIO\":13,\"name\":\"Air\",\"valueName\":\"Humidity\",\"Sensor\":\"DHT22\",\"aaa\":\"111\",\"bbb\":\"222\",\"ccc\":\"333\"},{\"id\":\"Air-2a\",\"Controller\":\"ESP72\",\"CntrTaskNo\":11,\"CntrGPIO\":14,\"name\":\"Air\",\"valueName\":\"Humidity\",\"Sensor\":\"DHT22\",\"aaa\":\"444\",\"bbb\":\"555\",\"ccc\":\"666\"},{\"id\":\"Air-1a\",\"Controller\":\"ESP62\",\"CntrTaskNo\":2,\"CntrGPIO\":9,\"name\":\"Air\",\"valueName\":\"Humidity\",\"Sensor\":\"DHT22\",\"aaa\":\"777\",\"bbb\":\"888\",\"ccc\":\"999\"},{\"id\":\"Air-1a\",\"Controller\":\"-\",\"CntrTaskNo\":10,\"CntrGPIO\":12,\"name\":\"Air\",\"valueName\":\"Humidity\",\"Sensor\":\"DHT22\",\"aaa\":\"777\",\"bbb\":\"888\",\"ccc\":\"999\"}]","tot":"json"}],"action":"","property":"","from":"","to":"","reg":false,"x":300,"y":140,"wires":[["762f6421.074fec"]]},{"id":"f827bddb.c9acd","type":"debug","z":"a7814b7e.3adeb8","name":"","active":true,"tosidebar":true,"console":false,"tostatus":false,"complete":"false","x":630,"y":140,"wires":[]},{"id":"762f6421.074fec","type":"change","z":"a7814b7e.3adeb8","name":"Jsonata $sort","rules":[{"t":"set","p":"payload","pt":"msg","to":"($a := $sort(payload,function($l , $r){$l.Controller > $r.Controller}) ; $sort($a,function($l , $r){(($l.Controller = $r.Controller) and ($l.CntrGPIO > $r.CntrGPIO))}))","tot":"jsonata"}],"action":"","property":"","from":"","to":"","reg":false,"x":460,"y":140,"wires":[["f827bddb.c9acd"]]}]

also tested in Jsonata exerciser: http://try.jsonata.org/S1IlT3y-E 在Jsonata锻炼器中也进行了测试: http ://try.jsonata.org/S1IlT3y-E

You can sort the array using the following expression: 您可以使用以下表达式对数组进行排序:

payload^(Controller, CntrDef.GPIO)

The order-by operator ^ will sort the array, first by increasing value of Controller , then by increasing value of CntrGPIO . 排序操作符^将首先通过增加Controller值,然后通过增加CntrGPIO值来对数组进行排序。 You can then transform each object within that array 然后,您可以变换该数组中的每个对象

payload^(Controller, CntrDef.GPIO).{
   "Controller" : Controller,
   "Cntr-TaskNo": CntrDef.TaskNo,
   "Cntr-GPIO"  : CntrDef.GPIO,
   "name"       : name,
   "valueName"  : valueName,
   "Sensor"     : Sensor,
   "id"         : id
}

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM