Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > Varios
Registrarse FAQ Miembros Calendario Guía de estilo Buscar Temas de Hoy Marcar Foros Como Leídos

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 25-05-2015
Avatar de lbidi
lbidi lbidi is offline
Miembro
 
Registrado: oct 2003
Ubicación: Montevideo- URUGUAY
Posts: 385
Poder: 16
lbidi Va por buen camino
Decodificar objeto json.

Estimados.

Tengo el siguiente array en formato json y necesito parsearlo o decodificar.

Código Delphi [-]
{"username":"155555" , "fecha_nacimiento": "2015-02-26" , '"ci": "18272617", "password":"", "telefono":"", "email":"", "direccion":"" }

Estoy usando XE5, mientras sigo probando.

Gracias.
Responder Con Cita
  #2  
Antiguo 26-05-2015
Avatar de duilioisola
[duilioisola] duilioisola is offline
Miembro Premium
NULL
 
Registrado: ago 2007
Ubicación: Barcelona, España
Posts: 1.512
Poder: 14
duilioisola Tiene un aura espectacularduilioisola Tiene un aura espectacular
Podrías hacer un bucle que busque las cadenas entre llaves.
En esa cadena busca las subcadenas separadas por comas.
De esa cadena busca las cadenas entre "dos puntos"
Quitas las comillas a las cadenas
La primera es el nombre del campo y la segunda es el valor.

También puedes recorrer de izquierda a derecha buscando comillas.
Teniendo en cuenta que siempre son pares, la primera parte es el nombre del campo y la segunda el valor.
Responder Con Cita
  #3  
Antiguo 26-05-2015
Avatar de Neftali [Germán.Estévez]
Neftali [Germán.Estévez] Neftali [Germán.Estévez] is offline
[becario]
 
Registrado: jul 2004
Ubicación: Barcelona - España
Posts: 15.895
Poder: 10
Neftali [Germán.Estévez] Tiene un aura espectacularNeftali [Germán.Estévez] Tiene un aura espectacular
Las ultimas versiones de Delphi poseen la unit System.JSON (ahora no recuerdo si se introdujo en XE5 o XE6).
Con ella puedes parsear fácilmente objetos de tipo JSON. Si le echas un vistazo a la docWiki seguro que hay ejemplos de cómo hacerlo.

Si en la versión que tienes no está, la opción es usar una unit externa. Yo, por ejemplo, he usado lkJSON (búscala por Internet) que funciona muy bien.

Librería lklJSON en Sourceforge
__________________
Germán Estévez => Web/Blog
Guía de estilo, Guía alternativa
Utiliza TAG's en tus mensajes.
Contactar con el Clubdelphi

P.D: Más tiempo dedicado a la pregunta=Mejores respuestas.
Responder Con Cita
  #4  
Antiguo 27-05-2015
Avatar de nlsgarcia
[nlsgarcia] nlsgarcia is offline
Miembro Premium
NULL
 
Registrado: feb 2007
Ubicación: Caracas, Venezuela
Posts: 2.206
Poder: 16
nlsgarcia Tiene un aura espectacularnlsgarcia Tiene un aura espectacular
lbidi,

Cita:
Empezado por lbidi
...Tengo el siguiente array en formato json y necesito parsearlo...


Revisa este código:
Código Delphi [-]
unit Unit1;

interface

uses
  Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
  Dialogs, StdCtrls, uLkJSON;

type
  TForm1 = class(TForm)
    ListBox1: TListBox;
    Button1: TButton;
    procedure Button1Click(Sender: TObject);
  private
    { Private declarations }
  public
    { Public declarations }
  end;

var
  Form1: TForm1;

implementation

{$R *.dfm}

// Read and Parse File JSON
procedure TForm1.Button1Click(Sender: TObject);
var
   SL, FieldList : TStringList;
   JS : TlkJSONobject;
   i : Integer;

begin

   SL := TStringList.Create;
   SL.LoadFromFile(ExtractFilePath(Application.ExeName) + 'FileTest.json');

   FieldList := TStringList.Create;

   JS := TlkJSONobject.Create;
   JS := TlkJSON.ParseText(SL.Text) as TlkJSONobject;

   for i := 0 to JS.Count - 1 do
   begin
      if JS.FieldByIndex[i].SelfType <> jsNull then
        FieldList.Add(JS.FieldByIndex[i].Value)
      else
        FieldList.Add(' ');
   end;

   ListBox1.Clear;
   for i := 0 to FieldList.Count - 1 do
      ListBox1.Items.Add(FieldList.Strings[i]);

   SL.Free;
   FieldList.Free;
   JS.Free;

end;

end.
El código anterior en Delphi 7 sobre Windows 7 Professional x32, Lee y analiza la estructura de un archivo .json (Msg #1) por medio de la librería lkJSON-1.07, como se muestra en la siguiente imagen:



Nota: La librería lkJSON-1.07, no necesita ser instalada, solo se debe copiar la unidad uLkJSON.pas al directorio del proyecto o agregar la ruta de la misma en el Library Path de Delphi.

Espero sea útil

Nelson.

Última edición por nlsgarcia fecha: 27-05-2015 a las 05:38:21.
Responder Con Cita
  #5  
Antiguo 27-05-2015
Avatar de nlsgarcia
[nlsgarcia] nlsgarcia is offline
Miembro Premium
NULL
 
Registrado: feb 2007
Ubicación: Caracas, Venezuela
Posts: 2.206
Poder: 16
nlsgarcia Tiene un aura espectacularnlsgarcia Tiene un aura espectacular
lbidi,

Cita:
Empezado por lbidi
...Tengo el siguiente array en formato json y necesito parsearlo...


Revisa este código:
Código Delphi [-]
unit Unit1;

interface

uses
  Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants, System.Classes, Vcl.Graphics,
  Vcl.Controls, Vcl.Forms, Vcl.Dialogs, Vcl.StdCtrls, System.JSON;

type
  TForm1 = class(TForm)
    ListBox1: TListBox;
    Button1: TButton;
    procedure Button1Click(Sender: TObject);
  private
    { Private declarations }
  public
    { Public declarations }
  end;

var
  Form1: TForm1;

implementation

{$R *.dfm}

// Read and Parse File JSON
procedure TForm1.Button1Click(Sender: TObject);
var
   SL, FieldList : TStringList;
   JS : TJSONObject;
   i : Integer;

begin

   SL := TStringList.Create;
   SL.LoadFromFile(ExtractFilePath(Application.ExeName) + 'FileTest.json');

   FieldList := TStringList.Create;

   JS := TJSONobject.Create;
   JS.Parse(BytesOf(SL.Text), 0);

   for i := 0 to JS.Count - 1 do
      FieldList.Add(JS.Pairs[i].JsonString.Value + ': ' + JS.Pairs[i].JsonValue.Value);

   ListBox1.Clear;
   for i := 0 to FieldList.Count - 1 do
      ListBox1.Items.Add(FieldList.Strings[i]);

   SL.Free;
   FieldList.Free;
   JS.Free;

end;

end.
El código anterior en Delphi XE7 sobre Windows 7 Professional x32, Lee y analiza la estructura de un archivo .json (Msg #1) por medio de la unidad System.JSON, como se muestra en la siguiente imagen:



Espero sea útil

Nelson.

Última edición por nlsgarcia fecha: 27-05-2015 a las 08:14:36.
Responder Con Cita
  #6  
Antiguo 29-05-2015
Avatar de lbidi
lbidi lbidi is offline
Miembro
 
Registrado: oct 2003
Ubicación: Montevideo- URUGUAY
Posts: 385
Poder: 16
lbidi Va por buen camino
Muchas gracias nlsgarcia..

Me ha sido muy util.
Responder Con Cita
  #7  
Antiguo 12-08-2015
amadis amadis is offline
Miembro
 
Registrado: may 2005
Ubicación: Colón, Entre Ríos, Argentina
Posts: 228
Poder: 15
amadis Va por buen camino
Que tal Amigos.

Quisiera saber si ese codigo de delphi XE7 funciona en XE5?.

yo lo he intentado y me está dando error al compilar.

[dcc32 Fatal Error] jsonsimple.pas(7): F1026 File not found: 'D:\Mis Documentos\RAD Studio\Projects\System.json.dcu' (unit scope "System" indicates Android, iOSDevice, Win32, Win64, OSX32, iOSSimulator only)

En otras pruebas que hice con JSON he usado la UNIT DBXjson y no tuve problemas pero ya al declarar la uses System.Json me marca error de sintaxis.

Será posible lograr lo mismo en XE5 sin componentes de terceros?.

Gracias
Responder Con Cita
  #8  
Antiguo 12-08-2015
Avatar de AgustinOrtu
[AgustinOrtu] AgustinOrtu is offline
Miembro Premium
NULL
 
Registrado: ago 2013
Ubicación: Argentina
Posts: 1.858
Poder: 10
AgustinOrtu Es un diamante en brutoAgustinOrtu Es un diamante en brutoAgustinOrtu Es un diamante en brutoAgustinOrtu Es un diamante en bruto
Quiere decir que no estaba la unit System.Json en XE 5

Fijate sino con REST.Json, aunque no estoy seguro si es exactamente la misma funcionalidad

Por otro lado, si con la DBXJson no tuviste problemas porque cambiarla?

Precisamente no recuerdo ahora si fue en StackOverflow o en el grupo de Google+ que lei que las implementaciones mas recientes que vienen en Delphi (System.Json y REST.Json) son algo flojas
Responder Con Cita
  #9  
Antiguo 12-08-2015
amadis amadis is offline
Miembro
 
Registrado: may 2005
Ubicación: Colón, Entre Ríos, Argentina
Posts: 228
Poder: 15
amadis Va por buen camino
Hola Agustín.

Aparantemente en las unit dbxjson o rest.json no estan las siguientes propiedades implementadas.

JS.Count JS.Pairs[].

Que vi en el ejemplo de este mismo post para acceder y visualizar los datos de un Json.
Responder Con Cita
  #10  
Antiguo 12-08-2015
amadis amadis is offline
Miembro
 
Registrado: may 2005
Ubicación: Colón, Entre Ríos, Argentina
Posts: 228
Poder: 15
amadis Va por buen camino
Por sugerencia del compañero Neftali he descargado la unit uLKJSON y lo he resuelto de esa forma.
Responder Con Cita
  #11  
Antiguo 12-08-2015
Avatar de AgustinOrtu
[AgustinOrtu] AgustinOrtu is offline
Miembro Premium
NULL
 
Registrado: ago 2013
Ubicación: Argentina
Posts: 1.858
Poder: 10
AgustinOrtu Es un diamante en brutoAgustinOrtu Es un diamante en brutoAgustinOrtu Es un diamante en brutoAgustinOrtu Es un diamante en bruto
Otra opcion muy buena es SuperObjects
Responder Con Cita
Respuesta


Herramientas Buscar en Tema
Buscar en Tema:

Búsqueda Avanzada
Desplegado

Normas de Publicación
no Puedes crear nuevos temas
no Puedes responder a temas
no Puedes adjuntar archivos
no Puedes editar tus mensajes

El código vB está habilitado
Las caritas están habilitado
Código [IMG] está habilitado
Código HTML está deshabilitado
Saltar a Foro

Temas Similares
Tema Autor Foro Respuestas Último mensaje
Como crear un objeto json lbidi Varios 3 14-05-2015 15:22:52
decodificar datos recibidos por COM jesmasuso Varios 1 29-11-2014 00:35:03
Decodificar y codificar una imagen djemix Gráficos 8 21-04-2012 00:45:42
decodificar offset JXJ Varios 0 24-07-2011 20:29:22
Decodificar año rafadrover SQL 4 11-01-2005 02:28:15


La franja horaria es GMT +2. Ahora son las 15:40:27.


Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2019, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi
Copyright 1996-2007 Club Delphi