JSON PARSE ARRAY
JSON PARSE ARRAY ( cadeiaJSON ; arrayObjeto )
Parâmetro | Tipo | Descrição | |
---|---|---|---|
cadeiaJSON | Text | → | Cadeia JSON a analisar |
arrayObjeto | Array | ← | Array que contém o resultado da análise da cadeia JSON |
Descrição
O comando JSON PARSE ARRAY analisa o conteúdo de uma cadeia com formato JSON e localiza os dados extraídos no array arrayObjeto. Este comando não realiza os dados JSON, realiza a ação inversa do comando JSON Stringify array.
Em cadeiaJSON, passe a cadeia com formato JSON cujo conteúdo deseja analisar. Esta cadeia deve ter o formato correto, caso contrário é gerado um erro de análise.
Em arrayObjeto, passe o objeto que deve receber os resultados da análise.
Note: A partir de 4D v16 R4, JSON PARSE ARRAY pode geralmente ser substituído por uma chamada a JSON Parse que retorna uma coleção. Coleções são baseadas em arrays JSON permite armazenar dados de diversos tipos, o que oferece mais flexibilidade que arrays.
Exemplo
Neste exemplo, os dados dos campos dos registros de uma tabela se extraem e localizam nos arrays de objetos:
var $ref : Object
ARRAY OBJECT($sel;0)
ARRAY OBJECT($sel2;0)
var v_String : Text
OB SET($ref;"name";->[Company]Company Name)
OB SET($ref;"city";->[Company]City)
While(Not(End selection([Company])))
$ref_company:=OB Copy($ref;True)
APPEND TO ARRAY($sel;$ref_company)
// $sel{1}={"name":"4D SAS","city":"Clichy"}
// $sel{2}={"name":"MyComp","city":"Lyon"}
// ...
NEXT RECORD([Company])
End while
v_String:=JSON Stringify array($sel)
// v_String= [{"name":"4D SAS","city":"Clichy"},{"name":"MyComp","city":"Lyon"}...]
JSON PARSE ARRAY(v_String;$sel2)
// $sel2{1}={"name":"4D SAS","city":"Clichy"}
// $sel2{2}={"name":"MyComp","city":"Lyon"}
//...