Top-Themen

AppleEntwicklungHardwareInternetLinuxMicrosoftMultimediaNetzwerkeOff TopicSicherheitSonstige SystemeVirtualisierungWeiterbildungZusammenarbeit

Aktuelle Themen

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

Inhalt aus csv Spalten aufschluesseln

Frage Entwicklung Batch & Shell

Mitglied: Arafat

Arafat (Level 1) - Jetzt verbinden

19.06.2008, aktualisiert 20.06.2008, 3710 Aufrufe, 6 Kommentare

Folgendes kleines Problem:

Ich habe eine csv Datei mit Inhalt:

"Text " "Zahl" "Zahlen"
"Nummer1" "01" "011 012 013"
"Nummer2" "02" "022 023 024 025"

ich möchte diese csv umformen in:


"Text " "Zahl" "Zahlen1" "Zahlen2" "Zahlen3" "Zahlen4"
"Nummer1" "01" "011" "012" "013" ""
"Nummer2" "02" "022" 023" 024" "025"

Fragt sich jetzt nur ob es dafür ein kleines Script gibt?

Vielen Dank schon mal im voraus.

Gruß Markus
Mitglied: bastla
19.06.2008 um 13:56 Uhr
Hallo Arafat!

Etwa so:
01.
@echo off & setlocal 
02.
echo "Text " "Zahl" "Zahlen1" "Zahlen2" "Zahlen3" "Zahlen4">D:\Ziel.csv 
03.
for /f "skip=1 tokens=1,2*" %%i in (D:\Quell.csv) do for /f "tokens=1-4" %%a in (%%k) do @echo %%i %%j "%%a" "%%b" "%%c" "%%d">>D:\Ziel.csv
Grüße
bastla
Bitte warten ..
Mitglied: Arafat
19.06.2008 um 14:30 Uhr
das klappt!

was aber wenn

"Text " "Zahl" "Zahlen" "Name"
"Nummer1" "01" "011 012 013" "Peter"
"Nummer2" "02" "022 023 024 025" "Micha"
"Nummer3" "03" "033 034" "Seb"

also die zu teilende Zelle von der Größe nicht bekannt ist udn danach noch weiter "einzel Zellen" kommen?

Danke aber trotzdem!!!!
Bitte warten ..
Mitglied: bastla
19.06.2008 um 16:49 Uhr
Hallo Arafat!

Soferne die Maximalanzahl an aus der Zerlegung des "Spezialfeldes" entstehenden Feldern bekannt ist, etwa so:
01.
@echo off & setlocal 
02.
set "Quelle=D:\Quell.csv" 
03.
set "Ziel=D:\Ziel.csv" 
04.
set /a FeldNr=3 
05.
 
06.
echo "Text " "Zahl" "Zahlen1" "Zahlen2" "Zahlen3" "Zahlen4" "Name">"%Ziel%" 
07.
for /f "usebackq skip=1 delims=" %%i in ("%Quelle%") do set "Zeile=%%i" & call :ProcessLine 
08.
goto :eof 
09.
 
10.
:ProcessLine 
11.
set /a Nr=1 
12.
set ZeileNeu= 
13.
for %%a in (%Zeile%) do call :ProcessField %%a 
14.
echo %ZeileNeu:~1%>>"%Ziel%" 
15.
goto :eof 
16.
 
17.
:ProcessField 
18.
set Feld=%1 
19.
if %Nr% neq %FeldNr% goto :Hinzu 
20.
for /f "tokens=1-4" %%a in (%1) do set "Feld="%%a" "%%b" "%%c" "%%d"" 
21.
 
22.
:Hinzu 
23.
set "ZeileNeu=%ZeileNeu% %Feld%" 
24.
set /a Nr+=1 
25.
goto :eof
Als %FeldNr% ist das weiter zu zerlegende Feld (im Beispiel also "Zahlen") anzugeben. Die Anzahl der Teile wird durch "tokens=1-4" und die Verwendung von "%%a" bis "%%d" im Programmteil ":ProcessField" festgelegt.

Grüße
bastla
Bitte warten ..
Mitglied: Arafat
20.06.2008 um 12:17 Uhr
Hallo bastla,

das Skript funktioniert ganz gut - nur schrieb er mir nur die erste Zeile in die Datei (Zeile 06) - alle weiter werden auf der console ausgegeben.

DAnke für deine Hilfe

Gruß Markus
Bitte warten ..
Mitglied: bastla
20.06.2008 um 14:07 Uhr
Hallo Arafat!

... alle weiter werden auf der console ausgegeben.
Kann ich mir nicht erklären, da die Zieldatei ja als Variable, welche sich nach der Zeile 3 nicht mehr ändert, angegeben ist - wenn also in Zeile 06 in die Datei geschrieben wird, müsste das auch Zeile 14 tun ...

Anyhow, versuch es mit dieser Zeile 14:
01.
>>"%Ziel%" echo %ZeileNeu:~1%
Grüße
bastla
Bitte warten ..
Mitglied: Arafat
20.06.2008 um 15:52 Uhr
Yes!

das ist es!

Vielen Dank!
Bitte warten ..
Ähnliche Inhalte
Datenbanken
gelöst T-SQL: Inhalt verschiedener Spalten in eine Spalte schreiben (2)

Frage von Suilven zum Thema Datenbanken ...

VB for Applications
Excel Makro zum Suchen von Spalten und exportieren in CSV (3)

Frage von Raptox zum Thema VB for Applications ...

VB for Applications
gelöst Bestimmte Spalten aus CSV-Datei auslesen (VBS) (9)

Frage von Gurkenhobel zum Thema VB for Applications ...

Java
gelöst Net user per script aus txt oder csv für FTP (15)

Frage von OlliPWS zum Thema Java ...

Neue Wissensbeiträge
Batch & Shell

Batch - ein paar Basics die man kennen sollte

Tipp von Pedant zum Thema Batch & Shell ...

Microsoft

Restrictor: Profi-Schutz für jedes Window

(5)

Tipp von AlFalcone zum Thema Microsoft ...

Batch & Shell

Batch zum Zurücksetzen eines lokalen Profils

Tipp von Mr.Error zum Thema Batch & Shell ...

Heiß diskutierte Inhalte
Microsoft Office
Saubere HTML aus Word-Dokument (16)

Frage von peterpa zum Thema Microsoft Office ...

Router & Routing
ASUS RT-N18U mit VPN Client hinter Fritzbox - Portforwarding (15)

Frage von marshall75000 zum Thema Router & Routing ...

Hosting & Housing
gelöst Webserver bei WIX, aber DNS Server wo anders (9)

Frage von laster zum Thema Hosting & Housing ...