AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

JSON parsen Performance

Ein Thema von Nebilim · begonnen am 1. Apr 2020 · letzter Beitrag vom 2. Apr 2020
Antwort Antwort
Nebilim

Registriert seit: 7. Jun 2019
Ort: Grafschaft B.
26 Beiträge
 
Delphi 10.3 Rio
 
#1

JSON parsen Performance

  Alt 1. Apr 2020, 09:35
Hi ihr JSON Profis,

ich bin wirklich ein Neuling im JSON.

ich bekomme ein JSON mit 75 einträgen á ca. 20 Key/Value paare.
Diese parse ich in Delphi in einer Schleife in einer TObjectList<TMyClass> und adde die 75 Klassen in die ObjectListe, damit ich die alle im zugriff habe. und wollte mir danach eine allgemeine klasse schreiben die aus eine OBjectList ein DataSet zurückgibt.

das ganze dauert schon 10 sec ohne das Dataset zu erzeugen, was mir ca. 9,5 sec zu lange dauert.

Mein primäres Ziel ist es die 75 Datensätze in ein Memorydataset o.ä. zu schreiben und an ein Grid zur Anzeige zu bringen.
Geht das ganze irgendwie schneller und besser? Ich will nämlich die ganze datenermittlung vom client weg auf den Server verlagern und benutze dazu JSON

Hoffe ihr versteht in etwa was ich möchte. Ich parse den JSON auch nur weil es so einfach geht mit dem richtigenaufbau der Klasse und TJson.JsonToObject<>

Geändert von Nebilim ( 1. Apr 2020 um 09:42 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von Uwe Raabe
Uwe Raabe

Registriert seit: 20. Jan 2006
Ort: Lübbecke
11.487 Beiträge
 
Delphi 12 Athens
 
#2

AW: JSON parsen Performance

  Alt 1. Apr 2020, 09:47
Einen String mit einer Liste von Json-Objekten in ein TDataSet zu überführen geht am einfachsten mit einem TRESTResponseDataSetAdapter
Uwe Raabe
Certified Delphi Master Developer
Embarcadero MVP
Blog: The Art of Delphi Programming
  Mit Zitat antworten Zitat
Bbommel

Registriert seit: 27. Jun 2007
Ort: Köln
659 Beiträge
 
Delphi 12 Athens
 
#3

AW: JSON parsen Performance

  Alt 1. Apr 2020, 10:01
Mal nur aus reiner Neugier nachgefragt, weil Uwe ja wahrscheinlich eh schon die passende Antwort geliefert hat:

Du schreibst, du würdest das JSON in einer Schleife parsen. Nutzt du dazu denn TJSONObject.ParseJSONValue oder machst du das irgendwie selber? Das würde mir nämlich etwas Sorgen machen, wenn TJSONObject.ParseJSONValue für 75 Datensätze mit je 20 Key/Wert-Paaren 10 Sekunden nur fürs Parsen brauchen würde.
  Mit Zitat antworten Zitat
Nebilim

Registriert seit: 7. Jun 2019
Ort: Grafschaft B.
26 Beiträge
 
Delphi 10.3 Rio
 
#4

AW: JSON parsen Performance

  Alt 1. Apr 2020, 10:04
ne wie ich beschrieben habe parse ich es direkt in eine Delphiklasse mit

lMyClass := TJson.JsonToObject<TmyCLass>(messagesJson.Items[i].ToString, [joDateIsUTC, joDateFormatISO8601]) die Klasse besitzt properties die automatisch geparst werden mit den Keys aus dem JSON weil ich die konventionen eingehalten habe.
  Mit Zitat antworten Zitat
Nebilim

Registriert seit: 7. Jun 2019
Ort: Grafschaft B.
26 Beiträge
 
Delphi 10.3 Rio
 
#5

AW: JSON parsen Performance

  Alt 2. Apr 2020, 08:37
Moin Uwe,

danke schonmal für die Nachricht, aber ich stehe damit gerade irgendwie auf dem kriegsfuß. Ich finde nicht heraus wie ich diese Komponente erfolgreich in einer Klasse ohne Oberfläche verwenden kann.

Kannst du mir da nochmal einen Denkanstoß geben?
  Mit Zitat antworten Zitat
Redeemer

Registriert seit: 19. Jan 2009
Ort: Kirchlinteln (LK Verden)
1.087 Beiträge
 
Delphi 2009 Professional
 
#6

AW: JSON parsen Performance

  Alt 2. Apr 2020, 08:45
Wie immer mit Create(nil) .
Janni
2005 PE, 2009 PA, XE2 PA
  Mit Zitat antworten Zitat
Antwort Antwort


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 03:18 Uhr.
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz