|
Antwort |
wollt eigentlich nur mal die ersten Fortschritte eines vor kurzem längerem begonnen Projektes vorstellen
es ist "nur" eine weitere kleine XML-Klasse. der Grund war eigentlich, daß mir andere XML-Projekte zu rießig sind und MSMXL (TXMLDocument) nicht grad schnell. [info] aktuell entwickle ich unter D2009 und direkt kompatibel düfte es bis Delphi 2006 / Turbo Delphi sein und Aufgrund einiger Anfragen versuch ich, sobald es da "gut" läuft, eine Extraversion weiter abwärtskompatibel zu machen ... mal sehn, bis wie weit runter das geht [/info] [add 04.01.2001] aktuell sieht es so aus, als wenn es schonmal bis zu D7 läuft [add/] aktueller Post: http://www.delphipraxis.net/internal...116416#1116416 #193
ansonsten bin ich für Tipps und Vorschläge dankbar [add 13.03.2009] ach ja falls der Name jemandem nich gefällt ... Beschwerden bitte an Matze richten [add] im Beitrag #193 wird etwas über die im Download mit enthalenen anderen XML-Libs geschrieben. [add] Achtung, beim Forenupgrad der DP sind die Dateikommentare verschwunden und die Dateinamen sind unglücklich importiert wurden. himxml_246.7z = v0.9 21.05.2009 himxml_164.7z = v0.99d 12.01.2010 other.7z = 30.12.2010 (only the "other" directory)
$2B or not $2B
Geändert von himitsu (30. Dez 2010 um 09:29 Uhr) |
Delphi 12 Athens |
#171
ich bin zwar dabei eine neue Hilfe zu basteln, aber das dauert noch ein bissl
aktuell ist aber einiges in Form einer Inline-Hilfe direkt in den Dateien z.B. schau hierfür mal in die Unit himXML.pas (bzw. himXMLi.pas der alten Version) und klappe dort ganz oben die Region "Help" auf (der zweite ganz lange Kommentar) ... Delphi 2009 sollte die Regionen ja standardmäßig zugeklappt haben. dort gibt es zu einigen Dingen schon eine kleine Erklärung z.B.
Code:
// Count CountNF -
// Node NodeNF (1) - // NodeU NodeUNF (1) see .Node but node always not created, ... // NodeList NodeListNF (1) -
Code:
schwer wird es nur, da ich mein "System" versuche auszulagern, so daß es mal möglich sein sollte auch sowas wie XPath nachzurüsten, bzw. mein System durch ein Alternatives oder Userdefinierte auszutauschen.
// (1) node names allowed paths, attributes and an index
// "{\}{.\}{..\}{node...\}{nodeName}{>attr=value{>attr=value{...}}}{[index]}" // // Node['\..\node'] Owner.RootNode.Parent.Node['node'] aka ... // Node['\node'] Owner.RootNode.Node['node'] or {first ... // Node['.\node'] {Self.}Node['node'] // Node['..\node'] Parent.Node['node'] // Node['node1\node2'] Node['node1'].Node['node2'] // Node['node>attr=value'] Node['node'] with Attributes['attr']='value' // Node['node>attr=value>attr2=value2'] Node['node'] with Attributes['attr']='value' and ... // Node['node[3]'] NodeList['node'][3] // Node['[3]'] Node[3] // Node['>attr=value'] first of Node.Nodes with Attributes['attr']='value' // Node['>attr=value[3]'] 3rd of Node.Nodes with Attributes['attr']='value' // Node['*:node'] ignore namespace // Node['name:*'] first/all nodes with this namespace // // Node['node1[2]\node2>attr=value[3]'] NodeList['node1'][2].NodeList['node2'][3] with ... // // (2) attribut names allowed paths - see at (1) // "{nodePath}\attributeName" // // Attribute['node\attr'] Node['node'].Attribute['attr'] also im Grunde sollte Node['tag1>attr=value'] funktionieren. |
Zitat |
Delphi 2009 Professional |
#172
Danke, das hilft mir sehr weiter. Ich hatte zwar schon in die Dateien mal reingeschaut, auch die einzelnen Regions gesehen (wusste gar nicht, dass es sowas gibt ), aber nicht wirklich etwas zu diesen Bezeichnungen gefunden. Hab vielleicht nicht genau genug gesucht ^^
Zu dem "tag1>attr=value" werd ich nochmal genauer schauen, warum das nicht funktioniert hatte. Diese "Abkürzungen" find ich übrigens sehr gut gelungen, da kommt man auch in etwas größeren Dokumenten relativ schnell an den eigentlichen Tag, den man lesen möchte (Gerade wenn man nicht alle Informationen benötigt) |
Zitat |
Delphi 12 Athens |
#173
Die Regionen sind schon 'ne praktische Sache, vorallem da man so auch Blöcke ausgeblendet bekommt, welche einem grade nicht "wichtig" sind und man so schneller und übersichtlicher an bestimmete Stellen kommt.
Nja, XPath und Dergleichen sind etwas mächtiger vom Funktionsumfang, aber für nette Kleinigkeiten ist mein winziges System auch schon zu gebrauchen. Abgesehn davon, daß hier auch schneller über Hashtabellen gesucht wird ... hab die Nodes und Attribute extra dafür optimiert. falls du Regionen auch mal selber nutzen willst...
Delphi-Quellcode:
dieses {$IF X}...{$IFEND} kannst'e ignorieren, das hab ich nur drinnen, weil ältere Delphis keine Regionen kennen
{$IF X}{$REGION 'help'}{$IFEND}
... {$IF X}{$ENDREGION}{$IFEND}
Delphi-Quellcode:
und beim Zusammenklappen wird dann nur noch der Text angezeigt ... ist praktisch das Selbe, was man mit Funktionen und Typen (Records/Klassen) machen kann, nur halt für größere Bereiche/Regionen
{$REGION 'beliebiger Text'}
... {$ENDREGION} |
Zitat |
Delphi 2009 Professional |
#174
Danke für die Antwort, wenn es sich das nächste Mal anbietet, weiß ich jetzt, wie ich etwas mehr Übersicht hineinbringen kann
Ich habe jetzt auch die Zeit gefunden, das Problem mit dem Zugriff mit Attribut-Wert genauer zu untersuchen, und nun funktioniert das auch. Da muss mir wohl beim letzten Mal ein Fehler unterlaufen sein (Tippfehler oder ähnliches), dein Code funktioniert also wie er soll |
Zitat |
Delphi 2009 Professional |
#175
Hallo himitsu!
Ich versuche gerade himXML in einem anderen Projekt einzusetzen. Dabei stellt sich mir die Frage, wie komme ich an die Attribute eines Nodes.
Delphi-Quellcode:
Die Datei sieht dabei so aus:
procedure TTag.LoadFromFile(const AFilename: string);
var f : TXMLFile; begin Parent := nil; // öffnen bla bla f := TXMLFile.Create; try f.LoadFromFile(AFilename); LoadFromNode(f['virtualroot\root']); finally f.Free; end; end; procedure TTag.LoadFromNode(const AXMLNode: TXMLNode); var na : string; i, ty: Integer; t : TEntry; nds : TXMLNodeArray; begin Name := AXMLNode.Node['name'].Text; nds := AXMLNode.NodeList['files\file']; for i := 0 to High(nds) do begin ty := nds[i]['@type'].Text; // Directory Node if (ty and 1) = 1 then begin t := TTag.Create; FChilds.Add(t); t.Parent := Self; TTag(t).LoadFromNode(nds[i]); end else begin t := TEntry.Create; FFiles.Add(t); t.Name := nds[i]['name'].Text; end; t.Hidden := (ty and 2) = 2; end; end;
XML-Code:
Wenn ich nun die Zeile 28 ausführe um den Type des Nodes "taxs\virtualroot\root\files\file[0]" zu kommen.
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<taxs> <virtualroot> <root> <name>Root</name> <files> <!-- Filecontainer with "filetype" Bit Meaning (if set) 1 Directory 2 Hidden --> <file type=1> <name>Sub</name> <files> <file type=3> <name>HiddenSub</name> </file> <file type=1> <name>Sub</name> <files> <file type=2> <name>HiddenFile</name> <original>C:...</original> </file> </files> </file> </files> </file> <file type=0> <name>Filetest</name> <original>C:...</original> </file> </files> </root> </virtualroot> </taxs>
Zitat:
---------------------------
text --------------------------- [EXMLException] TXMLNodeList.Add: invalid name ("@type") --------------------------- OK --------------------------- xZise
Fabian
|
Zitat |
Delphi 12 Athens |
#176
Im Prinzip einfach dadurch, daß man auf die Eigenschaft .Attributes den jeweiligen Nodes zugreift
ty := nds[i].Attributes['type']; |
Zitat |
Delphi 2009 Professional |
#177
Aha. Kann man das nicht irgendwie verkürzt schreiben?
Und jetzt habe ich ein ganz anderes komisches Problem. Und zwar wenn "LoadFromNode" gerade den "HiddenSub" Node abarbeitet, dann ist nds zwar "leer" (im Debugger steht: nds = ()), aber er geht trotzdem in die Schleife und scheitert dann grandios dabei das Attribut des ersten nicht vorhandenen Nodes auszulesen. MfG xZise
Fabian
|
Zitat |
Delphi 12 Athens |
#178
Zitat von xZise:
Aha. Kann man das nicht irgendwie verkürzt schreiben?
Zitat von xZise:
Und jetzt habe ich ein ganz anderes komisches Problem. ...
PS: was das Debuggen angeht ... In der neuen Version ist dieses in meinem Projekt standardmäßig abgeschaltet. (noch nicht hochgeladen) Und in der Beta läßt es sich über die Projektoptionen abstellen, dort einfach in den Bedingungen "hxNotDebugable" einfügen > D2009 > Projektoptionen > Delphi-Compiler > Bedingungen Dann läßt sich das eigene Programm einfacher debuggen, da nicht ständig im Einzelschritt in meine Units gewechselt wird. |
Zitat |
Delphi 12 Athens |
#179
Hab hier mal 'nen noch ungetesteten Code zum Speichern und Laden eines TTreeView.
Gespeichert wird natürlich der .Text und die ganzen Subnodes ... also die ganze Baum-Struktur des Trees und beim Rest kann man entschieden werden, was man speichern/laden will. Da wären die ganzen Bildindize .ImageIndex, .SelectedIndex, .StateIndex, .ExpandedImageIndex und .OverlayIndex, außerdem .Enabled und die Zustände .Selected, .Focused und .Expanded, für jeden einzelnen Node. Ein TVirtualStringTree wird auch bald folgen, dort wird .Data dann ebenso über einen Callback gespeichert und geladen.
Delphi-Quellcode:
benutzen
Type TSTVProc = Procedure(Node: TXMLNode; TVNode: TTreeNode);
TSTVSavedData = Set of (ssImageIndex, ssSelectedIndex, ssStateIndex, ssExpandedIndex, ssOverlayIndex, ssEnabled, ssSelected, ssFocused, ssExpanded, ssData); Const ssDefault = [ssImageIndex..ssSelected, ssExpanded]; Procedure SerializeTreeView(Node: TXMLNode; TreeView: TTreeView; Save: TSTVSavedData = ssDefault; DataProc: TSTVProc = nil); Procedure DeserializeTreeView(Node: TXMLNode; TreeView: TTreeView; Load: TSTVSavedData = ssDefault; DataProc: TSTVProc = nil);
Delphi-Quellcode:
Dieser und ähnliche Codes werden allerdings wohl nie direkt im Projekt enthalten sein, da sie einfach zu speziell sind,
Var XML: TXMLFile;
Node: TXMLNode; // speichern XML := TXMLFile.Create; Node := XML.AddNode('MyTreeView'); SerializeTreeView(Node, TreeView1); XML.SaveToFile('file.xml'); XML.Free; // laden XML := TXMLFile.Create; XML.LoadFromFile('file.xml'); Node := XML.Node['MyTreeView']; DeserializeTreeView(Node, TreeView1); XML.Free; aber es ist eine kleine Abteilung auf der zukünftigen Webseite vorgesehn. [edit] der ganze Code kommt gleich wieder ... dann als Anhang in 'ner eigenen Unit so, da isser wieder [add] nun auch getestet, etwas geändert und mit Beispiel, siehe Bild |
Zitat |
Delphi 12 Athens |
#180
Bis auf ein paar interne Sachen wurden vorallem ein paar neue Property eingefügt.
FindNode, FindNodes, FindNodeNF und FindNodesNF sind nun in den NodeListen zu finden, sowie als Weiterleitung im RootDokument und den Nodes. Diese sind fast das Selbe wie die Property Node und NodeList, nur daß sie die gewünscheten Nodes nicht NUR direkt im gewählten Node/Dokument suchen, sondern auch in allen SubNodes. Als NodeName/Pfad kann hier die selbe Syntax verwendet werden, wie bei den normalen Nodes, wodurch man z.B. auch ganze Pfade suchen kann. XML.FindNode['MeinNode'] würde also den ersten Node mit dem Namen "MeinNode" zurückliefern, welcher irgendwo innerhalb des RootNode oder seinen SubNodes rumliegt. Für Einzelnodes (ohne Pfadangabe) wird dieses Verhalten demnächst auch in den "normalen" Node und Node-Listen verfügbar sein ... ich glaub ich werde dieses über das Präfix @ dort integrieren. |
Zitat |
Ansicht |
Linear-Darstellung |
Zur Hybrid-Darstellung wechseln |
Zur Baum-Darstellung wechseln |
ForumregelnEs 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
|
|
Erstellt von | For | Type | Datum |
xml - MSXML alternative - Stack Overflow | This thread | Refback | 28. Jun 2011 16:34 |
Nützliche Links |
Heutige Beiträge |
Sitemap |
Suchen |
Code-Library |
Wer ist online |
Alle Foren als gelesen markieren |
Gehe zu... |
LinkBack |
LinkBack URL |
About LinkBacks |