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 mit batch bearbeiten - auslesen

Mitglied: webbudda

webbudda (Level 1) - Jetzt verbinden

29.07.2011 um 15:39 Uhr, 7557 Aufrufe, 10 Kommentare

Hallo,

ich habe viele unterordner mit *.csv-Dateien. Diese haben folgendes Format:

beispiel.csv:
name ; x
name 2 ; y
name 3 ; z
name 4 ; 1

beispiel2.csv:
name ; x2
name 2 ; y2
name 3 ; z2
name 4 ; 12

Aufgabe: alle csv-Dateien zusammen in eine einzelne mit folgendem Format zusammenführen.

alle.csv:
name; name 2; name 3; name 4
x; y; z; 1
x2; y2; z2; 12


Soweit war ich schon.
del alle.csv
dir /b /s *.csv > test.txt
echo name; name 2; name 3; name 4 >alle.csv
FOR /f "usebackq delims==" %%a IN (test.txt) DO type "%%a" >>alle.csv
del test.txt

Nur das "do" müsste sich jetzt so gestalten, dass er die erste "spalte" eines jeden csv ignioert. Kann mir dabei wer helfen?

Danke & gruß
Mitglied: Friemler
29.07.2011 um 16:18 Uhr
Hallo webbudda,

teste mal folgendes:
01.
@echo off & setlocal
02.

03.
set "SrcDir=E:\Test"
04.
set "DestDir=E:\Ausgabe"
05.
set "OutFile=%DestDir%\Alle.csv"
06.

07.
>"%OutFile%" echo Name;Name 2;Name 3;Name 4;
08.

09.
for %%f in ("%SrcDir%\*.csv") do (
10.
  for /f "usebackq tokens=1* delims=;" %%l in ("%%f") do (
11.
    >>"%OutFile%" <NUL set /p "=%%m;"
12.
  )
13.
  >>"%OutFile%" echo.
14.
)
Quell- und Zielverzeichnis müssen verschieden sein, sonst wird auch die Zieldatei von der äußeren FOR-Schleife gefunden und somit verarbeitet.

Kleiner Schönheitsfehler: Alle Zeilen der erzeugten CSV-Datei enden mit einem Semikolon, was quasi eine zusätzliche leere Spalte erzeugt. Falls die Datei nicht mit Excel weiterverarbeitet werden soll, einfach in Excel laden und nochmal als CSV speichern, dann verschwinden die abschließenden Semikolons.

Gruß
Friemler
Bitte warten ..
Mitglied: webbudda
29.07.2011 um 16:25 Uhr
Super, das klappt schon ganz gut. WIe kann ich das rekursiv gestalten, dass in %SrcDir% in allen unterordnern nach csv allen gesucht wird? thx
Bitte warten ..
Mitglied: Skyemugen
29.07.2011 um 16:27 Uhr
Aloha,

tja, heute ist Freitag, da bau ich wieder große Klötzchen *gg*

Wenn du wirklich nur vier Zeilen pro Datei hast und keine Semikola am Ende zusätzlich magst, hätte ich auch noch das meine übliche irgendwie geht das auch komplizierter - Nummer im Angebot:
01.
@echo off & setlocal enabledelayedexpansion
02.
set "Pfad=E:\Skripte\Ablage"
03.
set "Liste=E:\Skripte\alle.csv"
04.
if exist "%Liste%" del "%Liste%"
05.
>"%Liste%" echo name;name2;name3;name4
06.
for /f "delims=" %%s in ('dir /b /s "%Pfad%\*.csv"') do (
07.
	for /f "usebackq delims=; tokens=2" %%m in ("%%s") do (
08.
		set "Z4=!Z3!"
09.
		set "Z3=!Z2!"
10.
		set "Z2=!Z1!"
11.
		set "Z1=%%m"
12.
	)
13.
	>>"%Liste%" echo !Z4!;!Z3!;!Z2!;!Z1!
14.
	
15.
)
16.
pause
17.
goto :eof
greetz André

edit: Porzellan und so
Bitte warten ..
Mitglied: webbudda
29.07.2011 um 16:39 Uhr
Wenn das mit dem rekursiv noch rein kommt, ist alles gut. folgendes klappt nicht

for %%f in ('dir /b /s %SrcDir%\*.csv') do (
for /f "usebackq tokens=1* delims=;" %%l in ("%%f") do (
>>"%OutFile%" <NUL set /p "=%%m;"
)
>>"%OutFile%" echo.
)
Bitte warten ..
Mitglied: Friemler
29.07.2011 um 16:42 Uhr
Moin André,

der TO hat in seinen Beispieldaten bei "Name 4" numerische Werte angegeben. Keine Ahnung, ob das nun wirklich so ist oder ob es sich doch um Personennamen handelt. Bei numerischen Werten würde Dein Script aber möglicherweise in die Grütze fassen, da Du die Ausgabeumleitung hinter die Werte schreibst, die von ECHO ausgegeben werden. Dadurch könnte dann sowas wie echo x;y;z;2>>"%Liste%" entstehen. Somit würde diese Zeile als x;y;z; auf dem Bildschirm landen und nicht in der Datei.

Gruß
Friemler
Bitte warten ..
Mitglied: Friemler
29.07.2011 um 16:45 Uhr
Hallo webbudda,

sorry, das mit dem "rekursiv" habe ich verdrängt .

Versuche es mal so:
01.
@echo off & setlocal
02.

03.
set "SrcDir=E:\Test"
04.
set "DestDir=E:\Ausgabe"
05.
set "OutFile=%DestDir%\Alle.csv"
06.

07.
>"%OutFile%" echo Name;Name 2;Name 3;Name 4;
08.

09.
for /r "%SrcDir%" %%f in (*.csv) do (
10.
  for /f "usebackq tokens=1* delims=;" %%l in ("%%f") do (
11.
    >>"%OutFile%" <NUL set /p "=%%m;"
12.
  )
13.
  >>"%OutFile%" echo.
14.
)
Gruß
Friemler
Bitte warten ..
Mitglied: Skyemugen
29.07.2011 um 16:54 Uhr
Aloha Friemler,

in der Tat, das habe ich nicht bedacht aber im Test habe ich als Name 4 eine 1 und auch eine 2 und es stört ihn nicht, dennoch: sicher ist bestimmt sicher.

greetz André
Bitte warten ..
Mitglied: Friemler
29.07.2011 um 17:20 Uhr
Hallo André,

ah, das könnte mit der von Dir verwendeten verzögerten Variablenerweiterung zu tun haben, dann wird die Befehlszeile wohl anders geparst. Auch gut zu wissen.

Gruß
Friemler
Bitte warten ..
Mitglied: webbudda
31.07.2011 um 21:24 Uhr
Durchaus möglich, dass eine Zeile mit "2" endet. Würde also kein problem darstellen?
Bitte warten ..
Mitglied: Friemler
31.07.2011 um 22:45 Uhr
Hallo webbudda,

da Skyemugen sein Script geändert hat (und das anscheinend sowieso auch vorher kein Problem war), kannst Du beide der obigen Scripts verwenden.

Gruß
Friemler
Bitte warten ..
Ähnliche Inhalte
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 ...

Batch & Shell
Batch - .csv to .txt
gelöst Frage von freshman2017Batch & Shell11 Kommentare

Hallo Ihr, ich habe da nochmal eine leichte kurze Frage, vielleicht hat da jemand ein Code für mich. Folgende ...

Batch & Shell
Batch zum bearbeiten mehrerer CSV
Frage von Matzus87Batch & Shell3 Kommentare

Hallo Zusammen, ich bin neu hier und arbeite mich gerade in die Batch Programmierung ein. Ich sitze momentan an ...

Batch & Shell
XLXS zu CSV + Wert ersetzen - Batch
gelöst Frage von jochengBatch & Shell11 Kommentare

Hallo Leute ich habe ein Problem Ich brauch ein kleines Batch Script das ich täglich laufen lassen kann das ...

Neue Wissensbeiträge
Windows 7

Windows 7 u. Server 2008 (R2) SHA-2-Update kommt am 12. März 2019

Information von kgborn vor 44 SekundenWindows 7

Kleine Info für die Admins der oben genannten Maschinen. Ab Juli 2019 werden Updates von Microsoft nur noch mit ...

Firewall
PfSense 2.5.0 benötigt doch kein AES-NI
Information von ChriBo vor 1 TagFirewall1 Kommentar

Hallo, Wie sich einige hier erinnern werden hat Jim Thompson in diesem Aritkel beschrieben, daß ab Version 2.5.0 ein ...

Internet
Copyright-Reform: Upload-Filter
Information von Frank vor 3 TagenInternet1 Kommentar

Hallo, viele Menschen reden aktuell von Upload-Filtern. Sie reden darüber, als wären es eine Selbstverständlichkeit, das Upload-Filter den Seitenbetreibern ...

Google Android

Blokada: Tracking und Werbung unter Android unterbinden

Information von AnkhMorpork vor 3 TagenGoogle Android1 Kommentar

In Ergänzung zu meinem vorherigen Beitrag: Blokada efficiently blocks ads, tracking and malware. It saves your data plan, makes ...

Heiß diskutierte Inhalte
Backup
Wo installiert man Veeam bei SoHo?
Frage von EDVMan27Backup14 Kommentare

Hallo, nachdem ich die neue Veeam CE bei mir getestet habe, wollte ich es einmal bei einem Kunden testen. ...

CPU, RAM, Mainboards
Kann eine "virtuelle CPU" bei VMware die Leistung einer phys. CPU entsprechen ?
Frage von Troja71CPU, RAM, Mainboards11 Kommentare

Eine Software fordert im Betrieb 8 CPU mit x GHz Taktung. Verfügbar ist "nur" eine VM mit 8 vCPUs ...

Batch & Shell
Tasklist überprüfen
Frage von IleiesBatch & Shell10 Kommentare

Hallo zusammen, Wie kann ich in Batch überprüfen, ob gerade der Prozess "Skype.exe" ausgeführt wird? Also nicht so dass ...

SAN, NAS, DAS
Aktuelle Bauvorschläge für NAS
gelöst Frage von zuckelSAN, NAS, DAS9 Kommentare

Hallo zusammen, ich möchte gerne ein NAS. Ein NAS mit ZFS und FreeNAS und mehr als 4 Festplatten (auch ...