vb@rchiv
VB Classic
VB.NET
ADO.NET
VBA
C#
TOP-Angebot: 17 bzw. 24 Entwickler-Vollversionen zum unschlagbaren Preis!  
 vb@rchiv Quick-Search: Suche startenErweiterte Suche starten   Impressum  | Datenschutz  | vb@rchiv CD Vol.6  | Shop Copyright ©2000-2024
 
zurück

 Sie sind aktuell nicht angemeldet.Funktionen: Einloggen  |  Neu registrieren  |  Suchen

VB.NET - Ein- und Umsteiger
Re: XML Node aus Variable 
Autor: ModeratorDaveS (Moderator)
Datum: 09.09.10 20:50

Also, erstens (sei bitte nicht beleidigt falls du daran beteiligt warst) ist das ziemlich beispielhaft für schlechte Xml. Damit kann man kaum mit Xml-Werkzeugen sinnvoll umgehen, und gar nicht ohne fremde Sachen wie String.Split() zu verwenden. Sowas wäre meiner Meinung nach wesentlich besser
<?xml version="1.0" encoding="utf-8" ?> 
<files >
    <file name='PACK.TXT' fieldCount='9'>
        <field>Object_key,2,10</field>
        <field>Msg,33,4</field>
        <field>Created_on,38,10</field>
        ...
    </file>
    <file name='...'>
    ...
    </file>
    ...
</files>
Da ist alles einfacher und einheitlich und man kann viel leichter Xml-mäßig Abfragen erstellen. (fieldCount ist in der Tat auch überflüssig weil man mit XPath ganz leicht die Anzahl der Unterelemente feststellen kann). Eventuell wäre es vorteilhaft Attribute auch für die field-Elemente zu verwenden, wie name=, start=, length=, zB. Das wäre sowas wie
<field name='Object_key' start='2' length='10' />.
Sonst muss man umständlich Werte aus filelist holen und splitten, man weiß nicht wie die Elemente heißen ohne die Anzahl zu kennen, und die Namen wie file01 sind sowieso überflüssig, da sie sich ohnehin aus der Reihenfolge ergeben. Stell dir vor du willst alle Felder für dateiName=xxx bekommen und du weißt nicht mal wie die Felder heißen. So umgeschrieben kann man leicht XmlDocument und XPath einsetzen. ZB alle Felder einer Datei so auflisten
        Dim xd As New XmlDocument
        xd.Load("C:\Users\Testuser\Test\files.xml")
 
        For Each file As XmlNode In xd.SelectNodes( _
          "//files/file[@name='PACK.TXT']/field")
            Debug.WriteLine(String.Format("Name={0}, start={1}, length={2}", _
            file.Attributes("name").Value, file.Attributes("start").Value, _
            file.Attributes("length").Value))
        Next
Das sieht denn so aus:
Name=Object_key, start=2, length=10
Name=Msg, start=33, length=4
Name=Created_on, start=38, length=10
Ich weiß natürlich nicht was Sinn der Sache ist (irgendwie etwas schwer zu begreifen) und was du dann mit der Xml anstellen willst um konkret weitere Vorschläge zu machen. Bei allem Respekt vor dem versuchten Einsatz von modischer Xml sollte man vielleicht zuerst einigermassen damit vertraut sein bevor man mit dem Entwurf von Xml Schemas anfängt. Sonst wird man sehr wahrscheinlich mit wesentlichen Problemen bei der späteren Bearbeitung konfrontiert.

(geändert: fileCount sollte fieldCount sein).

________
Alle Angaben ohne Gewähr. Keine Haftung für Vorschläge, Tipps oder sonstige Hilfe, falls es schiefgeht, nur Zeit verschwendet oder man sonst nicht zufrieden ist

alle Nachrichten anzeigenGesamtübersicht  |  Zum Thema  |  Suchen

 ThemaViews  AutorDatum
XML Node aus Variable2.835Badenzer07.09.10 19:41
Re: XML Node aus Variable1.702ModeratorDaveS08.09.10 09:57
Re: XML Node aus Variable1.652Badenzer09.09.10 08:03
Re: XML Node aus Variable1.816ModeratorDaveS09.09.10 09:23
Re: XML Node aus Variable1.648Badenzer09.09.10 19:33
Re: XML Node aus Variable1.712ModeratorDaveS09.09.10 20:50
Re: XML Node aus Variable1.681Badenzer09.09.10 21:43
Re: XML Node aus Variable1.821ModeratorDaveS10.09.10 09:45

Sie sind nicht angemeldet!
Um auf diesen Beitrag zu antworten oder neue Beiträge schreiben zu können, müssen Sie sich zunächst anmelden.

Einloggen  |  Neu registrieren

Funktionen:  Zum Thema  |  GesamtübersichtSuchen 

nach obenzurück
 
   

Copyright ©2000-2024 vb@rchiv Dieter Otter
Alle Rechte vorbehalten.
Microsoft, Windows und Visual Basic sind entweder eingetragene Marken oder Marken der Microsoft Corporation in den USA und/oder anderen Ländern. Weitere auf dieser Homepage aufgeführten Produkt- und Firmennamen können geschützte Marken ihrer jeweiligen Inhaber sein.

Diese Seiten wurden optimiert für eine Bildschirmauflösung von mind. 1280x1024 Pixel