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

Textdatei: Datensätze zusammenfügen

Frage Entwicklung Batch & Shell

Mitglied: weltklasse

weltklasse (Level 1) - Jetzt verbinden

18.10.2013, aktualisiert 10:47 Uhr, 1024 Aufrufe, 6 Kommentare

Hallo,

ich habe eine Textdatei mit 300.000 Datensätzen.

01.
ID | Artikel | Textfeld 
02.
a1   ab123   xxx5 
03.
a1   ab123   34wwwwwww 
04.
a1   ab123   999sss555777999 
05.
b3   x1egr    dddfffggg 
06.
c5   4a44     rrrrr88888uuuuu 
07.
c5   4a44     qqqqrr 
08.
c5   4a44     123333 
09.
c5   4a44     rrr777
Das Ergebnis soll in eine separate Datei geschrieben werden und so aussehen:

============================================================= 
ID | Artikel | Textfeld 
a1   ab123   xxx5, 34wwwwwww, 999sss555777999 
b3   x1egr    dddfffggg 
c5   4a44     rrrrr88888uuuuu, qqqqrr, 123333, rrr777
Kann mir jemand bei dem Code helfen???
Mitglied: Budders
18.10.2013, aktualisiert um 10:41 Uhr
Hallo weltklasse,

ich habe ein ähnliches Programm geschrieben das aus einer liste im Format
01.
  
02.
lagerplatz 
03.
artikel 
04.
lagerplatz 
05.
...
das folgende Format macht
01.
lagerplatz artikel bestand


ich könnte mir vorstellen, dass mit ein paar Modifikationen damit ein Programm das für dich richtig ist erzeugt werden kann.
Ich habe gerade etwas viel zu tun daher stell ich dir einfach mal den kompletten Code unbearbeitet zur Verfügung, vielleicht bringt dich das ja weiter.
Mein Code ist bereits kommentiert also hoffe ich dass du dich darin gut zurecht findest

http://pastebin.com/hHXP2VT5

Ansonsten gehe ich davon aus, dass die hier ansässigen Experten eine tolle Lösung für dich bereit haben :p

MfG Budders
Bitte warten ..
Mitglied: weltklasse
18.10.2013 um 12:14 Uhr
Vielen Dank für den Link.

Sorry, aber leider bin ich nicht so fit um den Code auf meine Bedürfnisse umzuwandeln.

Kann mir da vielleicht jemand helfen?

Vielen Dank.
Bitte warten ..
Mitglied: bastla
18.10.2013, aktualisiert um 13:01 Uhr
Hallo weltklasse und willkommen im Forum!

Da Du weder die Trennung der einzelnen Felder, noch deren Inhalt näher beschrieben hast, ein Ansatz der (bis auf die Tatsache, dass Leerzeichen als Trennzeichen betrachtet werden und daher führende Leerzeichen - wie zB vor "dddfffggg" - auf der Strecke bleiben) mit Deinen angegebenen Beispieldaten funktioniert:
01.
@echo off & setlocal 
02.
set "Ein=D:\DieDatei.txt" 
03.
set "Aus=D:\DieneueDatei.txt" 
04.
 
05.
set "Zeile=ID ^| Artikel ^| Textfeld" 
06.
 
07.
del "%Aus%" 2>nul 
08.
for /f "usebackq skip=1 tokens=1,2*" %%a in ("%Ein%") do call :ProcessLine %%a %%b "%%c" 
09.
>>"%Aus%" echo %Zeile% 
10.
goto :eof 
11.
 
12.
:ProcessLine 
13.
if "%1%2" neq "%Zuletzt%" ( 
14.
    >>"%Aus%" echo %Zeile% 
15.
    set "Zeile=%1 %2 %~3" 
16.
    set "Zuletzt=%1%2" 
17.
) else ( 
18.
    set "Zeile=%Zeile%, %~3" 
19.
20.
goto :eof
Grüße
bastla
Bitte warten ..
Mitglied: weltklasse
18.10.2013 um 13:17 Uhr
Entschuldigung. Die Felder der Datei sind mit TAB-Schritt voneinander getrennt.
Bitte warten ..
Mitglied: bastla
18.10.2013, aktualisiert um 15:55 Uhr
Hallo weltklasse!

Dann eher so:
01.
@echo off & setlocal 
02.
set "Ein=D:\DieDatei.txt" 
03.
set "Aus=D:\DieneueDatei.txt" 
04.
 
05.
set "Zeile=ID	Artikel	Textfeld" 
06.
 
07.
del "%Aus%" 2>nul 
08.
for /f "usebackq skip=1 tokens=1,2* delims=	" %%a in ("%Ein%") do call :ProcessLine %%a %%b "%%c" 
09.
>>"%Aus%" echo %Zeile% 
10.
goto :eof 
11.
 
12.
:ProcessLine 
13.
if "%1%2" neq "%Zuletzt%" ( 
14.
    >>"%Aus%" echo %Zeile% 
15.
    set "Zeile=%1	%2	%~3" 
16.
    set "Zuletzt=%1%2" 
17.
) else ( 
18.
    set "Zeile=%Zeile%,%~3" 
19.
20.
goto :eof
Die Zeilen 5, 8 und 15 verwenden jetzt TAB als Trennzeichen (delimiter). In Zeile 18 musst Du selbst entscheiden, ob nach dem Komma ein Leerzeichen folgen soll oder (wie in der aktuellen Fassung) nicht ...

Grüße
bastla
Bitte warten ..
Mitglied: weltklasse
21.10.2013 um 08:10 Uhr
Hallo bastla,

vielen Dank für Deine Lösung. Klappt super.
Da zeigt es sich, wer wirklich Ahnung hat.
Bitte warten ..
Ähnliche Inhalte
Neue Wissensbeiträge
Batch & Shell

Batch zum Zurücksetzen eines lokalen Profils

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

RedHat, CentOS, Fedora

Fedora, RedHat, Centos: DNS-Search Domain setzen

(13)

Tipp von Frank zum Thema RedHat, CentOS, Fedora ...

Heiß diskutierte Inhalte
LAN, WAN, Wireless
VPN Tunnel aufbauen (16)

Frage von Hajo2006 zum Thema LAN, WAN, Wireless ...

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

Frage von marshall75000 zum Thema Router & Routing ...

Microsoft Office
Saubere HTML aus Word-Dokument (14)

Frage von peterpa zum Thema Microsoft Office ...

E-Mail
gelöst Probleme beim E-Mail Empfang (12)

Frage von TommyB83 zum Thema E-Mail ...