Este es el sitio web histórico de la documentación de 4D. La documentación se está trasladando progresivamente a developer.4d.com

Inicio

 
4D v20 R7
JSON PARSE ARRAY

JSON PARSE ARRAY 


 

JSON PARSE ARRAY ( cadenaJSON ; array ) 
Parámetro Tipo   Descripción
cadenaJSON  Cadena in Cadena JSON a analizar
array  Array in Array que contiene el resultado del análisis de la cadena JSON

El comando JSON PARSE ARRAY analiza el contenido de una cadena con formato JSON y ubica los datos extraídos en el parámetro array. Este comando deserializa los datos JSON, realiza la acción inversa del comando JSON Stringify array.

En cadenaJSON, pase la cadena con formato JSON cuyo contenido desea analizar. Esta cadena debe tener el formato correcto, de lo contrario se genera un error de análisis.

En array, pase un array que debe recibir los resultados del análisis.

Nota: a partir de 4D v16 R4, JSON PARSE ARRAY por lo general puede ser sustituida por una llamada a JSON Parse que devuelve una colección. Las colecciones se basan en arrays JSON y permiten almacenar datos de tipos mixtos, lo que ofrece más flexibilidad que los arrays.

Ejemplo  

En este ejemplo, los datos de los campos de los registros de una tabla se extraen y ubican en los arrays de objetos:

 C_OBJECT($ref)
 ARRAY OBJECT($sel;0)
 ARRAY OBJECT($sel2;0)
 C_TEXT(v_String)
 
 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"}
  //...



Ver también 

JSON Parse
JSON Stringify array

 
PROPIEDADES 

Producto: 4D
Tema: JSON
Número 1219

This command can be run in preemptive processes

 
CONTENIDO DE LA PÁGINA 
 
HISTORIA 

Creado por: 4D v14
Modificado: 4D v16 R4

 
ARTICLE USAGE

Manual de lenguaje 4D ( 4D v20 R7)