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

gelöst CSV Datei auslesen per Batch

Mitglied: LowMind

LowMind (Level 1) - Jetzt verbinden

21.07.2011 um 19:24 Uhr, 17786 Aufrufe, 7 Kommentare

Hallo,

folgendes Problem bereitet mir gerade Kopfzerbrechen.

Ich möchte eine CSV Datei auslesen und zwar die ersten 4 Spalten einer Zeiel - in der 5 Spalte steht der Wert, der als Dateiname übernommen werden soll.
Jede Zeile soll eine Datei sein.

Bsp. CSV Datei
235456 | 1205435 | det | dtm | 118303111
234566 | 1205515 | det | dtm | 118300112
235455 | 2135465 | det | dtm | 118300116

Ergebnis Dateiname 118303111.txt
Inhalt 235456 1205435 det dtm

Ergebnis Dateiname 118300112.txt
Inhalt 235466 1205515 det dtm

Ergebnis Dateiname 118300116.txt
Inhalt 235455 2135465 det dtm

Ist sowas überhaupt per Batch möglich? Und kann man einen Zeilenumbruch programmieren!

Danke für eure Hilfe

Gruß
LowMind
Mitglied: Friemler
21.07.2011 um 19:57 Uhr
Hallo LowMind,

das erfordert lediglich einen Oneliner direkt auf der Kommandozeile:
for /f "usebackq tokens=1-5 delims=;" %a in ("Datei.csv") do @(>"%e" echo %a %b %c %d)
In einem Batchfile müssen die Prozentzeichen verdoppelt werden.

Es kostet schon etwas Aufwand, keinen Zeilenumbruch beim Ausgeben von Werten zu erzeugen.

Gruß
Friemler
Bitte warten ..
Mitglied: bastla
22.07.2011 um 02:54 Uhr
... und falls die Datei nur "CSV" heißt, aber inhaltlich Deinem Beispiel entspricht (also als Trennzeichen "|" verwendet), ersetze delims=; durch delims=| ...

Grüße
bastla
Bitte warten ..
Mitglied: LowMind
22.07.2011 um 10:13 Uhr
Moin Friemler,

der Einzeiler ist schon fast perfekt, nur wofür stehen denn %b %c %d am Ende des Befehls.
Und die Datei heißt %e eigentlich soll sie ja wie die 5 Spalte heißen

Dadurch erhalte folgendes Ergebnis
235455;2135465;det;dtm;118300116 %b %c %d

Wie bekomm ich denn den Zeilenumbruch hin und evtl. auch das Semikolon weg?

Gruß
LowMind
Bitte warten ..
Mitglied: Friemler
22.07.2011 um 10:32 Uhr
Hallo LowMind,

%b, %c, %d und %e sind automatisch erzeugte Laufvariablen der FOR-Schleife. Automatisch erzeugt wegen tokens=1-5; dadurch wird FOR angewiesen, die Eingabedaten in 5 Teile (Tokens) zu zerlegen, für die 5 Variablen erstellt werden. Die Namen kommen dadurch zustande, dass ich in der Befehlszeile die Variable %a angegeben habe. Die automatisch erzeugten Variablen erhalten immer Namen, die vom Namen der angegebenen Variable ausgehend in alphabetisch aufsteigender Reihenfolge erzeugt werden. Als Markierung, wodurch die 5 Teile der Eingabedaten voneinander abgegrenzt werden, dient wegen delims=; das Semikolon. Siehe auch mein Tutorial zur FOR-Schleife.

Zur Fehlfunktion:
Du hast wahrscheinlich bastlas Rat befolgt, ohne ihn genau verstanden zu haben. Du hast ja anscheinend Semikolons als Trennzeichen in Deiner CSV-Datei, also musst Du meine Befehlszeile unverändert übernehmen.

Dein Problem mit dem angeblich fehlenden Zeilenumbruch verstehe ich nicht. Die Ausgabe wird auf jeden Fall mit einem Zeilenumbruch abgeschlossen. Das kannst Du überprüfen, indem Du die erzeugten Dateien in einen Texteditor lädst.

Gruß
Friemler
Bitte warten ..
Mitglied: LowMind
22.07.2011 um 10:42 Uhr
Hi Friemler,
Bastlas Anmerkung habe ich nicht übernommen - das "delims=" für das Trennzeichen steht - hab ich so begriffen.

ich habe deine Befehlszeile so übernommen und erhalte die Fehler.

Das mit dem Zeilenumbruch hätte ich mal genauer beschreiben sollen. ich möchte einen Zeilenumbruch nach dem auslesen der ersten beiden Spalten.

Ergebnis soll sein
235455;2135465;
det;dtm

Gruß Robin
Bitte warten ..
Mitglied: Friemler
22.07.2011 um 10:49 Uhr
Hallo LowMind;

"delims=" ist falsch, es muss "delims=;" heißen.

Btr. Deine neue Anforderung:
01.
for /f "usebackq tokens=1-5 delims=;" %a in ("Datei.csv") do @>"%e" (echo %a %b&echo.&echo %c %d)
Und wenn es jetzt immer noch nicht funktioniert, poste bitte den Inhalt Deiner CSV-Datei unter Verwendung der Codeformatierung für Plain Text, damit ich auch wirklich den original Inhalt zu sehen bekomme, unbeeinflusst vom Rendering der Forumssoftware.

Gruß
Friemler
Bitte warten ..
Mitglied: LowMind
22.07.2011 um 11:05 Uhr
Hi Friemler,

einfach nur Danke, es funktioniert super.

Warum ich nur den Befehl "delims=" geschrieben habe, war eigentlich nur zur Erklärung gedacht, dass ich begriffen habe, dass ich dort auch andere Trennzeichen angeben kann, wo nach getrennt werden soll.

Danke nochmal für die super Hilfe und ein schönes Wochenende

Gruß
LowMind
Bitte warten ..
Ähnliche Inhalte
Batch & Shell

Per Batch CSV Datei zeilenweise bereinigen

gelöst Frage von yakazaaBatch & Shell2 Kommentare

Hallo zusammen, ich muss eine CSV Datei in ein Programm importieren, die im Prinzip SO aussieht: Soweit so schlecht, ...

Windows XP

Zeilen einer zusammengeführten CSV Datei über Batch ändern

Frage von NelspruitWindows XP12 Kommentare

Hallo zusammen, ich habe über batch ca. 1000 CSV Datein (Messdaten) zusammengeführt. Das Ganze schaut nun in der neuen ...

Batch & Shell

Per Batch eine Spalte in eine CSV Datei einfügen

gelöst Frage von mayli01Batch & Shell13 Kommentare

Hallo Forum :) Folgende Ausgangssituation. Ich habe eine CSV Artikelliste mit insgesamt 9 Spalten, einer Kopfzeile und etwa 50 ...

Batch & Shell

CSV kleinerer Wert (Batch)

Frage von jochengBatch & Shell3 Kommentare

Ich habe eine CSV Datei mit folgendem Inhalt: 29664;24,95 29664;12,95 29645;9,95 29645;9,95 29655;12,95 29655;24,95 29664;24,95 29655,12,95 29655,24,95 29664;12,95 29664;24,95 ...

Neue Wissensbeiträge
Windows Mobile

Support für Windows Mobile endet im Dezember 2019

Information von transocean vor 15 StundenWindows Mobile

Moin, Microsoft empfiehlt als Alternative den Umstieg auf iOS oder Android, wie man hier lesen kann. Gruß Uwe

Internet

Kommentar: Bundesregierung erwägt Ausschluss von Huawei im 5G-Netz - Unsere Presse wird immer sensationsgieriger

Information von Frank vor 2 TagenInternet5 Kommentare

Hier mal wieder ein schönes Beispiel für fehlgeleiteten Journalismus und Politik zugleich. Da werden aus Gerüchten plötzlich Fakten, da ...

Windows 10

Netzwerk-Bug in allen Windows 10-Versionen durch Januar 2019-Updates

Information von kgborn vor 2 TagenWindows 101 Kommentar

Nur ein kurzer Hinweis für Admins, die Windows 10-Clients im Portfolio haben. Mit den Updates vom 8. Januar 2019 ...

Windows 10

Windows 10 V1809: Rollout ist gestartet - kommt per Windows Update

Information von kgborn vor 3 TagenWindows 102 Kommentare

Eine kurze Information für die Admins, die Windows 10 im Programm haben. Microsoft hat die letzte Baustelle (die Inkompatibilität ...

Heiß diskutierte Inhalte
TK-Netze & Geräte
TAPI auf einem Win2016Server installieren und einrichten
Frage von wstabelTK-Netze & Geräte32 Kommentare

Hallo liebe Admins, ich habe folgende Situation: 1 Windows Server 2016 Standard als DC 1 SNOM 710 IP-Telefon 1 ...

Off Topic
Darf ich ein Forum erstellen das Produkte eines Herstellers betrifft?
Frage von cyberwallOff Topic9 Kommentare

Hallo Community, ich habe da eine "rechtliche" bzw. allgemeine Frage zum erstellen von Foren. Darf ich als "normale Person" ...

DNS
SFTP über DynDNS nicht OK - über ext. IP funktioniert es
Frage von C.MorgensternDNS8 Kommentare

Hallo zusammen! Ich habe Probleme beim SFTP Zugriff auf eine Linux Maschine vom WAN aus über eine DynDNS Adresse. ...

Router & Routing
Unbekannte IPv4 Adresse im Routerprotokoll(Portweiterleitung)
gelöst Frage von tklustigRouter & Routing7 Kommentare

Hallo Leute, folgender Screenshot(ScanVersusPortForwarding.jpg) zeigt die im Routerprotokoll aufgezeigten Portweiterleitungen und alle von einem IPScanner eruierten IPv4 Adressen in ...