Top-Themen

Aktuelle Themen (A bis Z)

Administrator.de FeedbackApache ServerAppleAssemblerAudioAusbildungAuslandBackupBasicBatch & ShellBenchmarksBibliotheken & ToolkitsBlogsCloud-DiensteClusterCMSCPU, RAM, MainboardsCSSC und C++DatenbankenDatenschutzDebianDigitiales FernsehenDNSDrucker und ScannerDSL, VDSLE-BooksE-BusinessE-MailEntwicklungErkennung und -AbwehrExchange ServerFestplatten, SSD, RaidFirewallFlatratesGoogle AndroidGrafikGrafikkarten & MonitoreGroupwareHardwareHosting & HousingHTMLHumor (lol)Hyper-VIconsIDE & EditorenInformationsdiensteInstallationInstant MessagingInternetInternet DomäneniOSISDN & AnaloganschlüsseiTunesJavaJavaScriptKiXtartKVMLAN, WAN, WirelessLinuxLinux DesktopLinux NetzwerkLinux ToolsLinux UserverwaltungLizenzierungMac OS XMicrosoftMicrosoft OfficeMikroTik RouterOSMonitoringMultimediaMultimedia & ZubehörNetzwerkeNetzwerkgrundlagenNetzwerkmanagementNetzwerkprotokolleNotebook & ZubehörNovell NetwareOff TopicOpenOffice, LibreOfficeOutlook & MailPapierkorbPascal und DelphiPeripheriegerätePerlPHPPythonRechtliche FragenRedHat, CentOS, FedoraRouter & RoutingSambaSAN, NAS, DASSchriftartenSchulung & TrainingSEOServerServer-HardwareSicherheitSicherheits-ToolsSicherheitsgrundlagenSolarisSonstige SystemeSoziale NetzwerkeSpeicherkartenStudentenjobs & PraktikumSuche ProjektpartnerSuseSwitche und HubsTipps & TricksTK-Netze & GeräteUbuntuUMTS, EDGE & GPRSUtilitiesVB for ApplicationsVerschlüsselung & ZertifikateVideo & StreamingViren und TrojanerVirtualisierungVisual StudioVmwareVoice over IPWebbrowserWebentwicklungWeiterbildungWindows 7Windows 8Windows 10Windows InstallationWindows MobileWindows NetzwerkWindows ServerWindows SystemdateienWindows ToolsWindows UpdateWindows UserverwaltungWindows VistaWindows XPXenserverXMLZusammenarbeit

XML Datei per Batch auslesen und in excel oder txt kopieren

Frage Entwicklung Batch & Shell

Mitglied: JL.Fdez

JL.Fdez (Level 1) - Jetzt verbinden

28.05.2013 um 18:02 Uhr, 3845 Aufrufe, 2 Kommentare

Hallo an alle,

habe eine Frage die möglicherweise schon mal gestellt wurde.
Leider komme ich nicht weiter!?

Ich möchte in einer XML Datei bestimmte Felder auslesen und in eine Txt oder excel datei speichern.

Geht das mit Batch oder Vbs überhaupt?
Wenn ja, habt ihr einen Tipp.

hier ein einblich in die XML Datei
- <cpe-item name="cpe:/a:1024cms:1024_cms:0.7">
<title xml:lang="en-US">1024cms.org 1024 CMS 0.7</title>
<meta:item-metadata modification-date="2010-12-14T19:38:32.197Z" status="DRAFT" nvd-id="121218" />
</cpe-item>
- <cpe-item name="cpe:/a:1024cms:1024_cms:1.2.5">
<title xml:lang="en-US">1024cms.org 1024 CMS 1.2.5</title>
<meta:item-metadata modification-date="2010-12-14T19:38:32.240Z" status="DRAFT" nvd-id="121219" />

Ich bräuchte folgende Felder bzw. werte:
title --> das funktioniert mit Set "Xmltag=title" for /f "delims=>/< tokens=3" %%i in ('find "%xmltag%" %XMLDATEI%') do echo %%i
aber damit habe ich Probleme !
status
nvd-id

und sollte so aussehen
xxx.txt
"nvd-id";"title";"status"
"121218";"1024cms.org 1024 CMS 0.7";"DRAFT"
"121219";"1024cms.org 1024 CMS 1.2.5";"DRAFT"
"121214";"1024cms.org 1024 CMS 1.3.1";"DRAFT"
oder
xxx.xlsx
nvd-id title status
121218 1024cms.org 1024 CMS 0.7 DRAFT
121219 1024cms.org 1024 CMS 1.2.5 DRAFT
121214 1024cms.org 1024 CMS 1.3.1 DRAFT

kann mir einer Weiter helfen?

LG
Mitglied: colinardo
28.05.2013, aktualisiert 29.05.2013
Hi,
also mit VBS kann ich Dir weiterhelfen. Da du aber nur einen Ausschnitt aus deinem XML-File gepostet hast habe ich das Beispiel-XML-File mal erweitert damit es mit VBS funktioniert (da im XML Namespaces verwendet werden die im VBS-Script mit angegeben werden müssen)

Beispiel XML-File mit Namespace-Prefix-Deklaration
01.
<?xml version="1.0" encoding="utf-8"?> 
02.
<items xmlns:meta="http://www.meinServer.de/adresse"> 
03.
<cpe-item name="cpe:/a:1024cms:1024_cms:0.7"> 
04.
	<title xml:lang="en-US">1024cms.org 1024 CMS 0.7</title> 
05.
	<meta:item-metadata modification-date="2010-12-14T19:38:32.197Z" status="DRAFT" nvd-id="121218" /> 
06.
</cpe-item> 
07.
<cpe-item name="cpe:/a:1024cms:1024_cms:1.2.5"> 
08.
	<title xml:lang="en-US">1024cms.org 1024 CMS 1.2.5</title> 
09.
	<meta:item-metadata modification-date="2010-12-14T19:38:32.240Z" status="DRAFT" nvd-id="121219" /> 
10.
</cpe-item> 
11.
</items>
VBS-Code zum Parsen der XML-Datei und Exportieren in eine Textdatei
Variablen in Zeile 1 und 2 sind anzupassen.
01.
xmlFile = "D:\data.xml" 
02.
outputTextfile = "D:\output.txt" 
03.
Set xmlDoc = WScript.CreateObject("Msxml2.DOMDocument") 
04.
Set fso = WScript.CreateObject("Scripting.Filesystemobject") 
05.
 
06.
xmlDoc.async = False 
07.
xmlDoc.Load xmlFile 
08.
If xmlDoc.parseError.errorCode <> 0 Then 
09.
	WScript.Echo xmlDoc.parseError.reason 
10.
	WScript.Quit 1 
11.
End If 
12.
xmlDoc.setProperty "SelectionLanguage", "XPath" 
13.
xmlDoc.setProperty "SelectionNamespaces", "xmlns:meta='http://www.meinServer.de/adresse'" 
14.
 
15.
Set f = fso.OpenTextFile(outputTextfile, 2, True) 
16.
'Schreibe Text-Headers 
17.
f.WriteLine(Chr(34) & "nvdid" & Chr(34) & ";" & Chr(34) & "title" & chr(34) & ";" & Chr(34) & "status" & Chr(34)) 
18.
 
19.
Set oDoc = xmlDoc.documentElement 
20.
Set xmlCPEItems = oDoc.getElementsByTagName("cpe-item") 
21.
If xmlCPEItems.length > 0 Then 
22.
	For Each el In xmlCPEItems 
23.
		title = el.selectSingleNode("title").text 
24.
		status = el.selectSingleNode("meta:item-metadata").attributes.getNamedItem("status").text 
25.
		nvdid = el.selectSingleNode("meta:item-metadata").attributes.getNamedItem("nvd-id").text 
26.
		f.WriteLine(Chr(34) & nvdid & Chr(34) & ";" & Chr(34) & title & chr(34) & ";" & Chr(34) & status & Chr(34)) 
27.
	Next 
28.
End If 
29.
f.Close 
30.
Set xmlDoc = Nothing
Am besten du postest mal den Anfang der XML-Datei in dem die Namespace-Deklarationen vermerkt sein sollten dann passe ich Dir den Code an.

Bitte verwende Tags wenn du Code postest damit dieser nicht "verhunzt" wird. (Siehe FAQ)

Grüße Uwe
Bitte warten ..
Mitglied: Endoro
28.05.2013, aktualisiert 29.05.2013
Hallo JL.Fdez,

Mit pure batch sieht es so aus:
01.
@echo off&setlocal 
02.
set "outfile=out.csv" 
03.
 
04.
set "tfile=%temp%\%random%.tmp" 
05.
(for /f tokens^=3^,4^,6delims^=^<^>^" %%i in ('findstr "title meta" file') do ( 
06.
	if "%%k"=="" (<nul set/p"=%%i:") else echo(%%j:%%k 
07.
))>"%tfile%" 
08.
(for /f "usebackq tokens=1-3 delims=:" %%i in ("%tfile%") do echo("%%k","%%i","%%j")>"%outfile%" 
09.
del "%tfile%" 
10.
type "%outfile%"
Gruss!
Bitte warten ..
Ähnliche Inhalte
VB for Applications
XML Datei auslesen mit Excel
Frage von kaiuwe28VB for Applications10 Kommentare

Hallo zusammen, ich mal wieder Leider komme ich nicht weiter. Ich möchte aus einem Ordner mit mehreren XML Dateien ...

Batch & Shell
Mit Batch .txt auslesen und benutzen
gelöst Frage von GhostJumperHDBatch & Shell8 Kommentare

Ich habe folgendes Problem Ich möchte das W-Lan überlasten und möchte danach die .bat zur .exe umwandeln. Ich möchte ...

VB for Applications
Excel VBA XML-Nodes auslesen
Frage von chef1568VB for Applications4 Kommentare

Hallo zusammen, ich lese eine XML-Datei mittels DOMDocument-Methode aus. Ich möchte nun den Wert von <Text> aus der Stellenbezeichnung ...

Batch & Shell
Kopieren von Dateien aus .txt Liste
Frage von mippselBatch & Shell2 Kommentare

Hallo zusammen, ich habe folgendes Problem: Von den über 2000 pdf/docx Dateien würde ich mir gerne gewisse Dateien in ...

Neue Wissensbeiträge
Windows 10

Autsch: Microsoft bündelt Windows 10 mit unsicherer Passwort-Manager-App

Tipp von kgborn vor 21 StundenWindows 102 Kommentare

Unter Microsofts Windows 10 haben Endbenutzer keine Kontrolle mehr, was Microsoft an Apps auf dem Betriebssystem installiert (die Windows ...

Sicherheits-Tools

Achtung: Sicherheitslücke im FortiClient VPN-Client

Tipp von kgborn vor 22 StundenSicherheits-Tools

Ich weiß nicht, wie häufig die NextGeneration Endpoint Protection-Lösung von Fortinet in deutschen Unternehmen eingesetzt wird. An dieser Stelle ...

Internet

USA: Die FCC schaff die Netzneutralität ab

Information von Frank vor 1 TagInternet3 Kommentare

Jetzt beschädigt US-Präsident Donald Trump auch noch das Internet. Der neu eingesetzte FCC-Chef Ajit Pai ist bekannter Gegner einer ...

DSL, VDSL

ALL-BM200VDSL2V - Neues VDSL-Modem mit Vectoring von Allnet

Information von Lochkartenstanzer vor 1 TagDSL, VDSL2 Kommentare

Moin, Falls jemand eine Alternative zu dem draytek sucht: Gruß lks

Heiß diskutierte Inhalte
Windows Server
GPO nur für bestimmte Computer
Frage von Leo-leWindows Server13 Kommentare

Hallo Forum, gern würde ich ein Robocopy script per Bat an eine GPO hängen. Wichtig wäre aber dort der ...

Windows Server
KMS Facts for Client configuration
Frage von winlinWindows Server13 Kommentare

Hey Leute, wir haben in unserem Netz nun einen neuen KMS Server. Haben Bestands-VMs die noch nicht aktiviert sind. ...

Windows Tools
Software-Tool zum Entfernen von bösartigem Windows
Frage von emeriksWindows Tools11 Kommentare

Hi, siehe Betreff hat das jemals irgendjemand schonmal sinnvoll eingesetzt? (MRT) E.

Router & Routing
OpenWRT bzw. L.E.D.E auf Buffalo WZR-HP-AG300H - update
gelöst Frage von EpigeneseRouter & Routing11 Kommentare

Guten Tag, ich habe auf einem Buffalo WZR-HP-AG300H die alternative Firmware vom L.E.D.E Projekt geflasht. Ich bin es von ...