![]() |
Re: himXML (gesprochen himix ML)
Ach Platzhalter kann man auch verwenden? Wieder was dazu gelernt :mrgreen:
Schnell mal getestet, und scheint wunderbar zu funktionieren. Danke für die Hilfe :) |
Re: himXML (gesprochen himix ML)
Jupp, das geht auch. :mrgreen:
Du kannst dir auch einfach mal den kleinen "leicht" unvollständigen Help-Abschnitt ganz oben in der himXML.pas ansehn. |
Re: himXML (gesprochen himix ML)
Da hatte ich extra nochmal reingeschaut gehabt, da ich mich erinnern konnte, dass es irgendwas mit * gegeben hat, aber da konnte ich nur
Delphi-Quellcode:
finden. Deshalb dacht ichd ann, dass es '*' für komplett alle Knoten wohl nicht geben würde. Zumindest kommt es nicht direkt rüber, dass es eben * und ? als die bekannten Platzhalter gibt ;)
// Node['*:node'] ignore namespace
// Node['name:*'] first/all nodes with this namespace (Vielleicht wurde die Hilfe auch schon erweitert, ich nutze aktuell die v0.98) |
Re: himXML (gesprochen himix ML)
Ohhh, ich dachte ich hätte es erwähnt. :oops:
|
Re: himXML (gesprochen himix ML)
Liste der Anhänge anzeigen (Anzahl: 1)
Hallo himitsu,
ich habe mich hier halbwegs durch den Thread geackert, da ich auf der Suche nach einer zuverlässigen und zugleich schnellen Verarbeitung von XML bin. Nun habe ich mir die v0.99 beta und die v0.9 runtegeladen und leider konnte ich gleich die erste Datei, die ich mit Demo_tree ausprobieren wollte nicht laden. Der erste Versuch (v0.99 beta) lieferte mir nur eine undankbare Fehlermeldung mit line 0 und col 0. Dann habe ich die Version 0.9 ausprobiert und siehe da, der Hinweis auf Zeile 44 meiner Datei. An diese Stelle (Zeile 44) steht aber nichts, womit XML nicht klar kommt. Vielleicht ist dort noch eine kleine Lücke. Main XML spy sagt: well formed und valid. Ich hänge mal die verkleinerte Test-XML an, vielleicht kann der XML-Großmeister was dazu sagen. Wäre schon toll, wenn wir dieses MSXML-Monster austauschen könnten. |
Re: himXML (gesprochen himix ML)
Liste der Anhänge anzeigen (Anzahl: 1)
Zitat:
XML-Code:
Das Problem ist erstmal, daß aus irgendeinem Grund die nachfolgenden Nodes nach <link> nicht als Unterknoten weitergeführt werden
<links>
<link> <IssuesLink/> <object_uid> und demnach wird dann gemeckert, als das </link> vorbeikommt, da dort kein offenes <link> vorhanden ist. Den Grund kann ich so jetzt aber nicht rausfinden. - hab hier kein Delphi - und fahr diese Nacht auch noch für ein paar Tage weg. (hab 4 anstrengende Messetage vor mir) Sobald ich dann wieder Zeit hab, werd' ich den bösen Fehler mal suchen ... zumindestens sieht es wie ein Fehler in meiner Lib aus ... deine Datei scheint wohl OK zu sein. [edit] Sag mal, hast du die XML mit einem der beiden Demo_Tree-Programmen geöffnet? Konnte es grade auch nur mit diesen Testen, da ich nur diese, als einzige fertigkompilierte Programme, nutzen konnte. Dort gibt es eine "böse" Zeile, welche für einen kompatibilitätztest mit HTML-Dateien noch vorhanden ist (diese sollte ich demnächst mal entfernen)
Delphi-Quellcode:
Ein "link"-Node wird dadurch immer als "Single-Tag" angesehn ... also so als wäre er immer <link/>, selbst wenn <link> dasteht.
XML.ParsedSingleTags := 'meta|link|br|img';
Entferne diese Zeile aus der Demo und kompiliere sie neu, danach sollte es hoffentlich gehn. (kann's hier ja leider gerade nicht testen) [merke] Aber die Zeilenzählung in der Exceptionbehandlung muß ich mir dann auch mal ansehn, denn dieses "line 0 und col 0." sieht ja wohl nicht OK aus. |
Re: himXML (gesprochen himix ML)
Also SimpleXML kann die Datei problemlos einlesen :wink:
|
Re: himXML (gesprochen himix ML)
So, wird langsam Zeit für meine nächste Frage :p
Und zwar habe ich folgendes Problem: Ich brauche bestimmte Knoten, sagen wir <code>, die innerhalb von anderen Knoten sind. Am besten ein Beispiel:
Code:
Ich will nun die <code> innerhalb von <parent> und <child> haben, und nur diese, dh. ganz unten das <code> will ich nicht mehr.
<?xml version="1.0" encoding="utf-8" standalone="yes" ?>
<root> <parent> <child> <code name="will ich" /> <code name="das auch" /> </child> <child> <code name="auch" /> </child> </parent> <parent> <child> <code name="will ich auch" /> <code name="haben will" /> </child> </parent> <code name="den will ich nicht" /> </root> Aktuell habe ich eine 3fach verwendete Schleife, nicht gerade das Gelbe vom Ei. Auf Seite 13 oder so wurde .FindNodes() erwähnt, doch konnte ich damit nicht die gewünschten Knoten bekommen.
Delphi-Quellcode:
Die eigentliche Frage kannst du dir sicher schon denken: Gibt es einen hübscheren Weg als die 3fach-Verschachtelte Schleife, an die Knoten zu kommen? ^^
procedure Test;
var XML: TXMLFile; Node: TXMLNode; Codes: String; N1, N2, N3: TXMLNode; begin XML := TXMLFile.Create; XML.LoadFromFile('C.\test.xml'); // 3fache Schleife... Nicht schön, liefert aber das gewünschte Ergebnis for N1 in XML.NodeList['parent'] do for N2 in N1.NodeList['child'] do for N3 in N2.NodeList['code'] do Codes := Codes + sLineBreak + N3.Attributes['name']; // for Node in XML.FindNodes['parent\child\code'] do // Liefert nur den ersten <code> // for Node in XML.FindNodes['code'] do // Liefert logischerweise auch den letzten <code>, aber auch nicht alle anderen // Codes := Codes + sLineBreak + Node.Attributes['name']; ShowMessage(Codes); XML.Free; end; FindNodes() klingt ja nach dem, was ich suche, nur entweder kann ich es nicht richtig anwenden oder da ist noch ein Fehlerchen drin :stupid: MfG Zwoetzen |
Re: himXML (gesprochen himix ML)
Aktuell sind die Schleifen wohl das Beste.
Leider hat FindNodes wirklich ein paar "Macken". Darum arbeite ich schon seit 'ner Weile an einer XPath-Variante, aber leider hängt es da an einigen Stellen. (vorallem an einer ![]() .FindeNodes ohne Pfade sollte mit dieser Änderung bessere Ergebnisse liefern
Delphi-Quellcode:
XML.FindNodes['code'] findet zumindestens alle 6 Code-Nodes.
Function TXMLNodeList.GetFindNodeArray(Name: TWideString): TXMLNodeArray;
Var N: TXMLNode; A, A2: TXMLNodeArray; i, i2: Integer; Begin //Result := nil; //N := NodeU[Name]; //If Assigned(N) Then Begin // SetLength(Result, 1); // Result[0] := N; //End; {}Result := NodeList[Name]; A := NodeList['*']; For i := 0 to High(A) do Begin A2 := A[i].FindNodes[Name]; If Assigned(A2) Then Begin i2 := Length(Result); SetLength(Result, i2 + Length(A2)); MoveMemory(@Result[i2], @A2[0], Length(A2) * SizeOf(TXMLNode)); End; End; End; |
Re: himXML (gesprochen himix ML)
Nagut, dann bleib ich erstmal bei den Schleifen.
Auf Seite 12 unten klang es so, als seien diese Funktionen schon fertig, und entsprechend war ich vom Ergebnis etwas verunsichert. ;) Danke für die schnelle Auskunft :mrgreen: |
Alle Zeitangaben in WEZ +1. Es ist jetzt 04:51 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