gelöst Undefinierte XML mit verändertem Content mit Batch auslesen
pascallantzsch (Level 1) - Jetzt verbinden
17.09.2014 um 18:00 Uhr, 1411 Aufrufe, 12 Kommentare, 2 Danke
Hallo Community,
ich möchte eine Batch erstellen, die mir die mir meine Aufgaben erleichtert.
Dazu muss ich eine bzw. mehrer XML Dateien auslesen...
Dazu gibt es immer eine Index.xml die mir die Verweise auf die nächsten benötigten xml liefert
1. Ich kenne den Namen der XML (Index.xml)
das benötigte steht immer in der 2. Zeile
<IndexFile index="ordner:andereXML.zip" version="4.10.0" />
und ich möchte nur andereXML.zip oder ordner:andereXML.zip in eine neue .txt file schreiben
2. Der Name der Xml entspricht dem was ich gerade aus der Index.xml geholt habe (andereXML.zip)
das benötigte steht hier immer in der 8. Zeile
<FileName val="ordner2:file.zip" />
und ich benötige das zwischen den ", also ordner2:file.zip
Ich würde gerne sagen wie weit ich schon bin, aber leider habe ich bisher nicht gefunden, wie man mit batch etwas aus einer xml auslesen kann....
Und bei "Java ist auch eine Insel" bin ich erst bei Kapitel 3
Bin für jede erdenkliche Hilfe dankbar
greetz
ich möchte eine Batch erstellen, die mir die mir meine Aufgaben erleichtert.
Dazu muss ich eine bzw. mehrer XML Dateien auslesen...
Dazu gibt es immer eine Index.xml die mir die Verweise auf die nächsten benötigten xml liefert
1. Ich kenne den Namen der XML (Index.xml)
das benötigte steht immer in der 2. Zeile
<IndexFile index="ordner:andereXML.zip" version="4.10.0" />
und ich möchte nur andereXML.zip oder ordner:andereXML.zip in eine neue .txt file schreiben
2. Der Name der Xml entspricht dem was ich gerade aus der Index.xml geholt habe (andereXML.zip)
das benötigte steht hier immer in der 8. Zeile
<FileName val="ordner2:file.zip" />
und ich benötige das zwischen den ", also ordner2:file.zip
Ich würde gerne sagen wie weit ich schon bin, aber leider habe ich bisher nicht gefunden, wie man mit batch etwas aus einer xml auslesen kann....
Und bei "Java ist auch eine Insel" bin ich erst bei Kapitel 3
Bin für jede erdenkliche Hilfe dankbar
greetz
12 Antworten
- LÖSUNG rubberman schreibt am 17.09.2014 um 18:34:57 Uhr
- LÖSUNG pascallantzsch schreibt am 17.09.2014 um 18:59:57 Uhr
- LÖSUNG rubberman schreibt am 17.09.2014 um 19:03:36 Uhr
- LÖSUNG pascallantzsch schreibt am 17.09.2014 um 19:09:14 Uhr
- LÖSUNG rubberman schreibt am 17.09.2014 um 19:21:53 Uhr
- LÖSUNG pascallantzsch schreibt am 17.09.2014 um 19:29:53 Uhr
- LÖSUNG rubberman schreibt am 17.09.2014 um 20:18:32 Uhr
- LÖSUNG pascallantzsch schreibt am 17.09.2014 um 22:22:00 Uhr
- LÖSUNG rubberman schreibt am 17.09.2014 um 23:24:54 Uhr
- LÖSUNG pascallantzsch schreibt am 17.09.2014 um 22:22:00 Uhr
- LÖSUNG rubberman schreibt am 17.09.2014 um 20:18:32 Uhr
- LÖSUNG pascallantzsch schreibt am 17.09.2014 um 19:29:53 Uhr
- LÖSUNG rubberman schreibt am 17.09.2014 um 19:21:53 Uhr
- LÖSUNG pascallantzsch schreibt am 17.09.2014 um 19:09:14 Uhr
- LÖSUNG rubberman schreibt am 17.09.2014 um 19:03:36 Uhr
- LÖSUNG Endoro schreibt am 18.09.2014 um 02:13:46 Uhr
- LÖSUNG rubberman schreibt am 18.09.2014 um 22:18:40 Uhr
- LÖSUNG pascallantzsch schreibt am 24.09.2014 um 09:38:18 Uhr
- LÖSUNG rubberman schreibt am 18.09.2014 um 22:18:40 Uhr
- LÖSUNG pascallantzsch schreibt am 17.09.2014 um 18:59:57 Uhr
LÖSUNG 17.09.2014, aktualisiert um 18:39 Uhr
Hallo pascallantzsch, willkommen im Forum.
Batch ist grundsätzlich ungeeignet um XML zu verarbeiten, weil
Es ist also immer ein Lotteriespiel. Egal ...
Dein erstes Problemchen lässt sich (ungetestet) evtl. so lösen:
Deinen Punkt 2 verstehe ich allerdings nicht. Eine ZIP Datei ist kein XML und enthält binären Inhalt. Wo willst du da eine Zeile 8 und einem Plaintext Inhalt herholen?
Grüße
rubberman
Batch ist grundsätzlich ungeeignet um XML zu verarbeiten, weil
- XML in den unterschiedlichsten Zeichensätzen vorliegen kann
- XML Zeilenumbrüche und Leerzeichen zwischen Knoten ignoriert (der gesamte Inhalt könnte theoretisch in einer Zeile stehen und wäre trotzdem valide)
- Der Aufbau von XML sich an Knotenobjekten, Werten, Eigenschaften, CDATA Objekten etc. orientiert, Batch aber stupide zeilenweise abarbeitet.
Es ist also immer ein Lotteriespiel. Egal ...
Dein erstes Problemchen lässt sich (ungetestet) evtl. so lösen:
01.
@echo off &setlocal
02.
for /f skip^=1^ tokens^=2^ delims^=^" %%i in ('type "Index.xml"') do (
03.
if not defined filename for /f "tokens=2 delims=:" %%j in ("%%i") do (
04.
set "filename=%%j"
05.
setlocal EnableDelayedExpansion
06.
>"neue.txt" echo !filename!
07.
endlocal
08.
)
09.
)
Grüße
rubberman
LÖSUNG 17.09.2014, aktualisiert um 19:06 Uhr
Hallo, danke erstmal für die schnelle Antwort... Punkt 1 werde ich gleich mal testen...
Bei Punkt 2 habe ich mich etwas falsch ausgedrückt... es gibt einen zwischenschritt bei dem die zip entpackt wird und eine xml (mit dem selben namen) zum Vorschein kommt
Dass batch nicht unbedingt gut für die XML ist, habe ich schon gelesen... aber es geht trotzdem wurde mir gesagt... ich werde gleich mal deinen Code testen
Edit: der erste funktioniert einwandfrei
kann ich das noch so verändern, dass er vor dem, was er aus der xml hat eine http adresse hinzufügt?
also zum Beispiel http://meineSeite.de/ und dann die Abfrage aus der xml z.B. xmlcode1.zip
und dass es dann zusammen da steht, also http://meineSeite.de/xmlcode1.zip
Bei Punkt 2 habe ich mich etwas falsch ausgedrückt... es gibt einen zwischenschritt bei dem die zip entpackt wird und eine xml (mit dem selben namen) zum Vorschein kommt
Dass batch nicht unbedingt gut für die XML ist, habe ich schon gelesen... aber es geht trotzdem wurde mir gesagt... ich werde gleich mal deinen Code testen
Edit: der erste funktioniert einwandfrei
kann ich das noch so verändern, dass er vor dem, was er aus der xml hat eine http adresse hinzufügt?
also zum Beispiel http://meineSeite.de/ und dann die Abfrage aus der xml z.B. xmlcode1.zip
und dass es dann zusammen da steht, also http://meineSeite.de/xmlcode1.zip
LÖSUNG 17.09.2014 um 19:03 Uhr
es gibt einen zwischenschritt bei dem die zip entpackt wird und eine xml (mit dem selben namen) zum Vorschein kommt
OK, und welches Programm hast du installiert, mit dem du kommandozeilengesteuert die ZIP Datei auspacken kannst?Grüße
rubberman
LÖSUNG 17.09.2014 um 19:09 Uhr
winrar
derzeit nutze ich für diesen schritt aber den jitbit macro recorder
aber in der kommandozeile dürfte dies ja mit
start C:\Program Files\WinRAR\WinRAR.exe x C:\Temp\macro\Index.zip *.* C:\Temp\macro\
gehen
derzeit nutze ich für diesen schritt aber den jitbit macro recorder
aber in der kommandozeile dürfte dies ja mit
start C:\Program Files\WinRAR\WinRAR.exe x C:\Temp\macro\Index.zip *.* C:\Temp\macro\
gehen
LÖSUNG 17.09.2014, aktualisiert um 19:23 Uhr
winrar
derzeit nutze ich für diesen schritt aber den jitbit macro Recorder
Von Macrorecordern habe ich keinen Schimmer. Die winrar Zeile sollte so auch nicht funktionieren, da der Pfad Leerzeichen enthält. START (ohne /WAIT) ist auch kontraproduktiv, da asynchron gearbeitet wird. Teste:derzeit nutze ich für diesen schritt aber den jitbit macro Recorder
01.
start "" /wait "C:\Program Files\WinRAR\WinRAR.exe" x C:\Temp\macro\Index.zip *.* C:\Temp\macro\
kann ich das noch so verändern, dass er vor dem, was er aus der xml hat eine http adresse hinzufügt?
Kann man. Schreibe sie einfach vor !filename! in die ECHO Ausgabe. Falls das aber bedeutet, dass du die Datei erst downloaden musst, ist das noch mal was ganz anderes.Es macht wenig Sinn wenn du häppchenweise mit deinen Anforderungen kommst ...
Grüße
rubberman
LÖSUNG 17.09.2014, aktualisiert um 19:50 Uhr
Ok, danke erstmal für die Hilfe ich wollte es so knapp wie möglich halten, soll ja nicht so rüber kommen, als würde ich mich hier anmelden und mir mein programm quasi schreiben lassen das will ich auch nicht
hab mich jetzt an punkt 2 gewagt... erst dachte ich ich nutze !filename! um in der selben batch den herusgefundenen text als 2. dateinamen mit xml dahinter zu nehmen... hat nicht geklappt
als nächstes dachte ich, dass ich in einer 2. batch den namen aus der generierten txt irgendwie heraus nehme, herausholen klappt, aber wie setze ich das dann als dateinamen?
müsste dann ja so sein
set filename2 = !filename!
for /f skip^=1^ tokens^=2^ delims^=^" %%i in ('type "filename2.xml"') do ( usw....
hab mich jetzt an punkt 2 gewagt... erst dachte ich ich nutze !filename! um in der selben batch den herusgefundenen text als 2. dateinamen mit xml dahinter zu nehmen... hat nicht geklappt
als nächstes dachte ich, dass ich in einer 2. batch den namen aus der generierten txt irgendwie heraus nehme, herausholen klappt, aber wie setze ich das dann als dateinamen?
müsste dann ja so sein
set filename2 = !filename!
for /f skip^=1^ tokens^=2^ delims^=^" %%i in ('type "filename2.xml"') do ( usw....
LÖSUNG 17.09.2014, aktualisiert um 22:14 Uhr
soll ja nicht so rüber kommen, als würde ich mich hier anmelden und mir mein programm quasi schreiben lassen
Das finde ich völlig in Ordnung, führt aber zu Verwirrungen.So was wie ...
1. ...
2. ...
3. ...
4. ...
Wobei ich für 2. und 3. bereits folgende Lösungen habe:
...
... würde ungemein helfen (ggf. auch Leuten mit ähnlichen Problemen).2. ...
3. ...
4. ...
Wobei ich für 2. und 3. bereits folgende Lösungen habe:
...
01.
@echo off &setlocal
02.
for /f skip^=1^ tokens^=2^ delims^=^" %%i in ('type "Index.xml"') do (
03.
if not defined filename1 for /f "tokens=2 delims=:" %%j in ("%%i") do (
04.
set "filename1=%%j"
05.
set "basename1=%%~nj"
06.
setlocal EnableDelayedExpansion
07.
>"neue1.txt" echo http://meineSeite.de/!filename1!
08.
endlocal
09.
)
10.
)
11.
12.
:: download, winrar etc.
13.
14.
for /f skip^=7^ tokens^=2^ delims^=^" %%i in ('type "C:\Temp\macro\%basename1%.xml"') do (
15.
if not defined filename2 for /f "tokens=2 delims=:" %%j in ("%%i") do (
16.
set "filename2=%%j"
17.
set "basename2=%%~nj"
18.
setlocal EnableDelayedExpansion
19.
>"neue2.txt" echo !filename2!
20.
endlocal
21.
)
22.
)
23.
24.
:: Testausgabe
25.
echo "%basename1%"
26.
echo "%basename2%
27.
pause
Grüße
rubberman
EDIT %basename% zu %basename1% in Zeile 14
LÖSUNG 17.09.2014 um 22:22 Uhr
Super, hat mit nen paar Änderungen und dem hinzufügen einer 3. Sache, damit ich noch das vor dem Doopelpunkt aus 2 bekomme geklappt... hier nochmal der Code
@echo off &setlocal
for /f skip^=1^ tokens^=2^ delims^=^" %%i in ('type "Index.xml"') do (
if not defined filename1 for /f "tokens=2 delims=:" %%j in ("%%i") do (
set "filename1=%%j"
set "basename1=%%~nj"
setlocal EnableDelayedExpansion
>"neue1.txt" echo !filename1!
endlocal
)
)
:: download, winrar etc.
for /f skip^=7^ tokens^=2^ delims^=^" %%i in ('type "%basename1%.xml"') do (
if not defined filename2 for /f "tokens=2 delims=:" %%j in ("%%i") do (
set "filename2=%%j"
set "basename2=%%~nj"
setlocal EnableDelayedExpansion
>"neue2.txt" echo !filename2!
endlocal
)
)
for /f skip^=7^ tokens^=2^ delims^=^" %%i in ('type "%basename1%.xml"') do (
if not defined filename3 for /f "tokens=1 delims=:" %%j in ("%%i") do (
set "filename3=%%j"
set "basename3=%%~nj"
setlocal EnableDelayedExpansion
>"neue3.txt" echo !filename3!
endlocal
)
)
:: Testausgabe
echo "%basename1%"
echo "%basename2%"
echo "%basename3%"
pause
@echo off &setlocal
for /f skip^=1^ tokens^=2^ delims^=^" %%i in ('type "Index.xml"') do (
if not defined filename1 for /f "tokens=2 delims=:" %%j in ("%%i") do (
set "filename1=%%j"
set "basename1=%%~nj"
setlocal EnableDelayedExpansion
>"neue1.txt" echo !filename1!
endlocal
)
)
:: download, winrar etc.
for /f skip^=7^ tokens^=2^ delims^=^" %%i in ('type "%basename1%.xml"') do (
if not defined filename2 for /f "tokens=2 delims=:" %%j in ("%%i") do (
set "filename2=%%j"
set "basename2=%%~nj"
setlocal EnableDelayedExpansion
>"neue2.txt" echo !filename2!
endlocal
)
)
for /f skip^=7^ tokens^=2^ delims^=^" %%i in ('type "%basename1%.xml"') do (
if not defined filename3 for /f "tokens=1 delims=:" %%j in ("%%i") do (
set "filename3=%%j"
set "basename3=%%~nj"
setlocal EnableDelayedExpansion
>"neue3.txt" echo !filename3!
endlocal
)
)
:: Testausgabe
echo "%basename1%"
echo "%basename2%"
echo "%basename3%"
pause
LÖSUNG 17.09.2014, aktualisiert um 23:25 Uhr
Das kannst du abkürzen.
Je nachdem, was du tatsächlich benötigst, kannst du ggf. noch weiter einkürzen.
Grüße
rubberman
01.
for /f skip^=7^ tokens^=2^ delims^=^" %%i in ('type "%basename1%.xml"') do (
02.
if not defined filename2 (
03.
set "property2=%%i"
04.
for /f "tokens=1,2 delims=:" %%j in ("%%i") do (
05.
set "folder2=%%j"
06.
set "filename2=%%k"
07.
set "basename2=%%~nk"
08.
REM * Für den Test auskommentiert: *
09.
REM setlocal EnableDelayedExpansion
10.
REM >"neue2.txt" echo !filename2!
11.
REM endlocal
12.
)
13.
)
14.
)
15.
16.
echo "%property2%"
17.
echo "%folder2%"
18.
echo "%filename2%"
19.
echo "%basename2%"
Grüße
rubberman
LÖSUNG 18.09.2014 um 02:13 Uhr
Batch ist grundsätzlich ungeeignet um XML zu verarbeiten, weil
Hey,
@rubberman grundsätzlich hast du natürlich recht, aber... häufig kann xml ganz gut gebatcht werden. Die Struktur muss exakt eingehalten werden (wie immer bei Batch), 1-Byte-Zeichencodierung (ANSI), zeilenorientierte Fragestellung. Dann geht sogar Regex, obwohl das ja quasi verboten ist. Manchmal helfen die xmlStarlet Tools weiter.
Gruss, Endoro
LÖSUNG 18.09.2014 um 22:18 Uhr
Hi Endoro.
Grüße
rubberman
Zitat von Endoro:
@rubberman grundsätzlich hast du natürlich recht, aber... häufig kann xml ganz gut gebatcht werden. Die Struktur muss exakt eingehalten werden (wie immer bei Batch), 1-Byte-Zeichencodierung (ANSI), zeilenorientierte Fragestellung.
Joa, wenn oben nicht etwas wie "immer in der X. Zeile" gestanden hätte, hätte ich auch nicht mit Batch gestartet, sondern (wie üblich) gleich auf das XML DOM verwiesen. Für/gegen unterschiedliche Zeichensätze hilft TYPE auch schon mal aus dem gröbsten heraus.@rubberman grundsätzlich hast du natürlich recht, aber... häufig kann xml ganz gut gebatcht werden. Die Struktur muss exakt eingehalten werden (wie immer bei Batch), 1-Byte-Zeichencodierung (ANSI), zeilenorientierte Fragestellung.
Dann geht sogar Regex, obwohl das ja quasi verboten ist.
LOL That would have been a link for the "Humor" forum as well Manchmal helfen die xmlStarlet Tools weiter.
Kannte ich noch nicht. Danke! Persönlich halte ich es dann aber doch lieber mit dem WSH (weil es ohne 3rd Party Tools auskommt).Grüße
rubberman
LÖSUNG 24.09.2014 um 09:38 Uhr
Nochmal Vielen Dank
Ähnliche Inhalte
Neue Wissensbeiträge
Heiß diskutierte Inhalte