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 Dateien Zusammenkopieren und bestimmte Zeilen entfernen

Mitglied: t3mp

t3mp (Level 1) - Jetzt verbinden

17.01.2008, aktualisiert 22.01.2008, 13620 Aufrufe, 4 Kommentare

Hallo,

Ich habe einen Ordner voller *.csv Dateien und möchte diese per Batch zu einer Datei zusammenfügen... bis dahin kein Problem.
Allerdings hat jede der *.csv Dateien die in dem Ordner liegen eine Überschrift (Zeile 1).

Diese Überschrift ist sehr lang (ca. 500 Zeichen) und sie soll in der erzeugten Datei nur einmal am Anfang auftauchen.

Hat jemand eine Idee wie ich das Problem lösen kann?

Danke für eure Hilfe!
Mitglied: bastla
17.01.2008 um 21:16 Uhr
Hallo -t3mp-!

Unter der Annahme, dass die genannte Überschrift in allen Dateien identisch ist und daher aus einer beliebigen Datei entnommen werden kann, sowie dass es keine vorgegebene Reihenfolge für die Bearbeitung der einzelnen Dateien gibt, etwa so:
01.
@echo off & setlocal 
02.
set "Ordner=D:\DeinOrdner" 
03.
set "Sammel=D:\DeineSammeldatei.csv" 
04.
 
05.
pushd "%Ordner%" 
06.
if exist "%Sammel%" del "%Sammel%" 
07.
for %%i in (*.csv) do if not exist "%Sammel%" for /f "usebackq delims=" %%z in ("%%i") do if not exist "%Sammel%" echo %%z>"%Sammel%" 
08.
for %%i in (*.csv) do more +1 "%%i">>"%Sammel%" 
09.
popd
Alternativ dazu könntest Du auch einfach vorweg die (vermutlich auch in Zukunft gleich bleibende) Zeile 1 in eine Datei "D:\DeinOrdner\Zeile1.txt" speichern und es danach so versuchen:
01.
@echo off & setlocal 
02.
set "Ordner=D:\DeinOrdner" 
03.
set "Sammel=D:\DeineSammeldatei.csv" 
04.
set "Zeile=D:\DeinOrdner\Zeile1.txt" 
05.
 
06.
copy "%Zeile%" "%Sammel%" >nul 
07.
copy "%Ordner%\*.csv" "%Sammel%.tmp" >nul 
08.
findstr /v /b /c:"Eine ganz lange Ueberschrift" "%Sammel%.tmp">>"%Sammel%" 
09.
del "%Sammel%.tmp"
Hier bist Du zwar weniger flexibel, da bei einer allfälligen Änderung der Zeile 1 nicht nur die zugehörige "Zeile1.txt", sondern auch der Suchstring "SignifikanterZeilenanfangZeile1" im Batch angepasst werden muss, solltest aber andererseits von Leerzeilen in der Sammeldatei verschont bleiben.

Der genannte Suchstring soll so viele Zeichen vom Beginn der Zeile 1 an enthalten, dass damit diese Zeile sicher erkannt und aus der temporären Sammeldatei ausgefiltert werden kann. Es dürfen übrigens auch Leerzeichen Bestandteil dieses Suchstrings sein.

Grüße
bastla
Bitte warten ..
Mitglied: t3mp
17.01.2008 um 21:51 Uhr
Hallo bastla,

danke für deine schnelle Hilfe!

Mit meinen 3 Test-Dateien funktionieren beide Lösungen von dir Problemlos!
Denke mal das es mit den Daten die ich zusammenfügen will auch hinhaut.

Hintergrund des ganzen ist:
Eine Klima-Kammer misst jede Stunde die Temperatur und viele andere Werte in seinem inneren & schreibt diese am ende eines Tages in eine JAHR-MONAT-TAG.csv Datei. Jeden Tag wird also eine neue Datei angelegt. Wenn man dann, die über einen Zeitraum von mehreren Monaten erzeugten Daten betrachten möchte macht sich das mit vielen einzelnen Dateien schlecht.

Mit der Batch-Lösung sind ja die Daten in der Ausgabedatei dann auch gleich Chronologisch geordnet.

Super!
Bitte warten ..
Mitglied: bastla
17.01.2008 um 22:09 Uhr
Hallo -t3mp-!

Um die chronologische Ordnung (anhand des Änderungsdatums der jeweiligen Datei) sicherzustellen, wäre es so besser:
01.
@echo off & setlocal 
02.
set "Ordner=D:\DeinOrdner" 
03.
set "Sammel=D:\DeineSammeldatei.csv" 
04.
 
05.
pushd "%Ordner%" 
06.
if exist "%Sammel%" del "%Sammel%" 
07.
for %%i in (*.csv) do if not exist "%Sammel%" for /f "usebackq delims=" %%z in ("%%i") do if not exist "%Sammel%" echo %%z>"%Sammel%" 
08.
for /f "delims=" %%i in ('dir /b /od *.csv') do more +1 "%%i">>"%Sammel%" 
09.
popd
Noch ein Hinweis: Derzeit ist der Batch darauf ausgelegt, bei jedem Start eine neue Sammeldatei aus allen vorhandenen .csv-Dateien zu erstellen - falls dies nicht gewünscht wäre, sondern die aktuelle Sammeldatei nur (und dann natürlich ohne Kopfzeile) ergänzt werden soll, einfach die Zeile
01.
if exist "%Sammel%" del "%Sammel%"
durch das Voranstellen von REM oder :: auskommentieren (oder auch löschen). Allerdings müssten dann nach jedem Durchlauf die bereits verarbeiteten Dateien aus dem Ordner entfernt werden.

Grüße
bastla
Bitte warten ..
Mitglied: t3mp
22.01.2008 um 18:05 Uhr
Hallo bastla,

vielen Dank nochmals für deine Hilfe.

Das Zusammenkopieren der Dateien funktioniert problemlos.

viele Grüße!
Bitte warten ..
Ähnliche Inhalte
Batch & Shell

Bestimmte Zeile aus CSV TXT auslesen und ausgeben

gelöst Frage von rst1989Batch & Shell4 Kommentare

Hallo zusammen, ich benötige bitte eine Hilfestellung bei folgender Problemstellung. Ich habe eine Text-Datei (txt) was eigentlich eine CSV-Datei ...

Batch & Shell

Per Batch Datei am Anfang einer .csv einer zeile mit bestimmten Inhalt einfügen und wieder speichern

Frage von FuxxLiBatch & Shell1 Kommentar

Hallo, ich habe folgende Herausforderung. Die Warenwirtschaft des Kunden exportiert nur Dateien mit einer Kopfzeile. Ein Dienstleister benötigt aber ...

Batch & Shell

Über eine Batch Datei (oder Konsole) bestimmte Spalten einer CSV Datei entfernen bzw. nur bestimmte Spalten behalten

gelöst Frage von vcdweltBatch & Shell4 Kommentare

Hallo, ich würde gerne per Batch Datei den Inhalt einer CSV Datei bearbeiten. Ursprüngliche Datei: Header1;Header2;Header3:Header4;Header5;Header6 Wert1;Wert2;Wert3;Wert4;Wert5;Wert6 Wert11;Wert22;Wert33;Wert44;Wert55;Wert66 Ziel ...

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 ...

Neue Wissensbeiträge
Hardware

100.000 Mikrotik-Router ungefragt von Hacker abgesichert

Information von 7Gizmo7 vor 2 StundenHardware

Hallo zusammen, da hier ja öfters mal von Mikrotik gesprochen wird. Trotz Updates klafft eine Sicherheitslücke in Hundertausenden Mikrotik-Routern. ...

Sicherheit

Oracle gibt kritische Updates für diverse Produkte frei (16. Oktober 2018)

Information von kgborn vor 13 StundenSicherheit

Oracle hat zum 16. Oktober 2018 eine ganze Reihe an kritischen Updates für seine Produkte freigegeben. Eine Kurzübersicht mit ...

Windows 10
FYI: Fristen beim Windows 10 Downgrade-Recht
Information von kgborn vor 13 StundenWindows 10

Möglicherweise ist das bei euch bekannt - ich habe es gerade aus einem Newsletter eines OEMs herausgefischt. Beim Downgrade-Recht ...

CMS
Freie Wähler Bayern MySQL PW online
Information von sabines vor 17 StundenCMS6 Kommentare

Die Typo3 Installation der Freien Wähler Bayern scheint wohl längere Zeit nicht mehr angefasst und/oder fehlkonfiguriert zu sein. Nach ...

Heiß diskutierte Inhalte
Windows 10
Sysprep Fehler im Log kann nicht starten
Frage von grillinator95Windows 1021 Kommentare

Hallo, kann leider SYSPREP nicht mehr starten, Win10 64bit. Logfile sagt folgendes: 2018-10-17 13:44:56, Info SYSPRP 2018-10-17 13:44:56, Info ...

Internet
Ist diese URL denkbar (Syntax)?
gelöst Frage von departure69Internet17 Kommentare

Hallo. Der Sohn eines Arbeitskollegen hat im Gymnasium EDV-Unterricht. Leider hat er in der letzten Klassenarbeit einen Fünfer geschrieben. ...

Exchange Server
Outlook Anywhere - Anmeldefenster muss mit Domain gefüllt werden
Frage von leon123Exchange Server15 Kommentare

Hallo zusammen, ich habe relativ erfolgreich einen Exchange 2016 aufgesetzt, sowie ein SAN-Zertifikat eingespielt und Outlook Anywhere aktiviert. Beim ...

Debian
Linux debian 9 Installation
Frage von Green14Debian15 Kommentare

Hallo zusammen, ich habe mich ein wenig mit Debian auseinandergesetzt und möchte mir eine Standard-Installation als Grundlage für andere ...