AW: XML parsen, aber wie
Warum versuchen eigentlich ständig Alle auf Biegen und Brechen nicht das zu verwenden, was dafür gedacht ist?
http://stackoverflow.com/questions/3...p-xml-response http://www.office-loesung.de/ftopic312578_0_0_asc.php http://howtoprogram.eu/question/n-a,55664 Bei einer XML auf die Idee zu kommen das mit sonstwas zu parsen ... braucht nur mal die Quelle die XML anders zu Formatieren und schon knallt es, obwohl sich am Inhalt garnichts ändert. Gut, wer krank ist, der kann statt des fehleranfälligen Pos/Copy-Codes es mit einem etwas weniger fehleranfälligen RegEx versuchen. :roll: Aber, auch wenn die Anwort eine XML ist, so ist das ganze eigentlich nur die Rückantwort eines Remote-Procedure-Call Dokumentation: http://evatr.bff-online.de/eVatR/xmlrpc/ Beispiel: http://evatr.bff-online.de/evatrRPC?...trasse=&Druck= Delphi XML RPC |
AW: XML parsen, aber wie
Nu komm mal runter.
Wer arbeitet sich in die Feinheiten von XML ein nur weil alle Jubeljahre mal (zuverlässig) eine Datei vorbei kommt. Insbesondere wenn die notorischen Besserwisser einem im Genick sitzen "das ist doch auch nur eine Textdatei, warum brauchen Sie dann so lange?" Gruß K-H P.S. Dank für die vielen Links, da ist die Mittagspause gerettet. |
AW: XML parsen, aber wie
Hallo,
Zitat:
nehme ich eine StringList und Pos, warum auch nicht? Wenn's funktioniert? Das war jetzt hier als Bsp., und nicht für die Xml des TE, die kommt ja aus der "Fremde". |
AW: XML parsen, aber wie
'ne abgewandelte Version für die, die Angst um veränderte Zeilenumbrüche haben:
Delphi-Quellcode:
Und nun haben wir im Wechesel jeweil Beschreibung und den Text dazu.
var
sl : TStringList; s : String; i : Integer; sErrorCode : String; begin ... Try idHttp1 := TIdHTTP.Create; sl := TStringList.Create; Screen.Cursor := crHourGlass; try s := IdHTTP1.Get(sUrlLong); IdHTTP1.Disconnect(True); // Tags werden vom Inhalt getrennt, indem sie je Tag in eine Zeile kommen s := AnsiReplaceText(s,'<',#13#10 + '<'); s := AnsiReplaceText(s,'>','>' + #13#10); sl.Text := s; // Tags brauchen wir nicht, ebensowenig wie Leerzeilen. for i := sl.Count - 1 downto 0 do begin if (Copy(sl[i],1,1) = '<') or (sl[i] = '') then sl.Delete(i); end; i := sl.IndexOf('ErrorCode'); if i > -1 then sErrorCode := sl[i + 1]; except on E: EIdException Do FormMain.add_info('UST Abfrage gescheitert ' + E.Message); end; Finally sl.Free; idHttp1.Free; Screen.Cursor := crDefault; End; Damit könnte man dann mit wenig Aufwand auch alles in 'ne Datenbank übernehmen. Und ja, es geht auch mit 'nem XML-Parser. |
AW: XML parsen, aber wie
Die Abfrage klingt irgendwie falsch:
Delphi-Quellcode:
Außerdem werden da auch die Endtags (/>) nicht berücksichtigt.
// Tags brauchen wir nicht, ebensowenig wie Leerzeilen.
for i := sl.Count - 1 downto 0 do begin if (Copy(sl[i],1,1) = '<') or (Copy(sl[i],1,1) = '<') or (sl[i] = '') then sl.Delete(i); end; Ich würde auch einen XML-Parser nehmen. Ist initial zwar mehr Aufwand, aber wenn die Formatierung mal eine andere ist, funktioniert es noch. Bei den ganzen Stringreplaces muss nur einmal anstatt <tag></tag> nur ein <tag /> stehen und es geht möglicherweise schon gar nicht mehr. |
AW: XML parsen, aber wie
Oh, da war ein Schreibfehler drinne, muss latürnich
Delphi-Quellcode:
heißen.
// Tags brauchen wir nicht, ebensowenig wie Leerzeilen.
for i := sl.Count - 1 downto 0 do begin if (Copy(sl[i],1,1) = '<') or (sl[i] = '') then sl.Delete(i); end; Alle Zeilen, die mit 'nem < beginnen, fliegen raus, ebenso alle Leerzeilen. Endetags mussen hier nicht separat berücksichtigt werden, weil sie im XML, um das es hier geht, nicht vorkommen. Wir haben hier immer mehr oder weniger viele öffnende Tags. Dann den Inhalt. Dann die entsprechende Anzahl schließender Tags. Wenn nun vor die < und hinter die > jeweils ein Zeilenumbruch eingefügt wird, dann sind alle Tags separiert. Sie und die ggfls. entstehenden Leerzeilen fliegen raus und übrig bleibt der Inhalt. Natürlich ist das nicht auf beliebige XML-Dateien anwendbar, aber danach war auch nicht gefragt. Das "Schöne" an dieser Vorgehensweise: Sie funktioniert auch noch dann, wenn man fehlerhaftes XML bekommt, bei dem "richtige" Parser zu Recht streiken. Mit dieser Vorgehensweise funktioniert seit Jahren meine Suchmaschine für HTML-Seiten. Es ist wurscht, ob die Seiten gültiges HTML enthalten und von Browsern/Parsern richtig oder näherungsweise interpretiert werden können. Als Ergbenis erhalte ich immer ausschließlich den Text der Seiten und kann ihn, nach entsprechender Weiterverarbeitung, in den Suchindex eintragen. |
AW: XML parsen, aber wie
Hallo,
also, wenn das Format der Datei verschieden sein kann, ist die Benutzung von TStringList falscher als ein Xlm-Parser. Wer weiss, was die da alles machen, dass bekommt man mit TStringList gar nicht alles hin (unter Umständen). |
AW: XML parsen, aber wie
Moin...:P
Ich wollte mich eigentlich heraushalten. :wink: Was habt ihr gegen einen XML Parser? (:wink: ausgenommen die die das auch vorgeschlagen haben) Es gibt nicht nur die mit dem Overhead von TXMLDocument...:roll: Beispiel (mit himXML):
Delphi-Quellcode:
...fertsch. 8-)
uses
himXML; ... XML: TXMLFile; ... XML := TXMLFile.Create; ... XML.LoadFromFile(FFileName); //XML.LoadFromStream(Stream); ErrorString := XML.Node['Errors'].Node['ErrorCode'].Text_S; // Beispiele für Node Bezeichnungen :-) |
AW: XML parsen, aber wie
Hallo,
nicht wenn das so aussieht <value><string>ErrorCode</string></value> <value><string>200</string></value> <value><string>300</string></value> </data></array></value> Oder müsste das nicht so aussehen? <value><array><data> <value><string>ErrorCode</string></value> <value><string>200</string></value> <value><string>ErrorCode</string></value> <value><string>300</string></value> </data></array></value ? |
AW: XML parsen, aber wie
Es gibt in einer Antwort des Servers nur einen ErrorCode, nämlich den zu den abgefragten Daten.
Ein Satz kann immer nur einen Fehlercode enthalten sein. Hier jetzt Probleme zu lösen, die nur dann auftreten, wenn man eine nicht der Spezifikation entsprechende Antwort bekommt, halte ich für übertrieben. |
Alle Zeitangaben in WEZ +1. Es ist jetzt 09:48 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz