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, 1017 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 ..
Neuester Wissensbeitrag
Windows 10

Powershell 5 BSOD

(8)

Tipp von agowa338 zum Thema Windows 10 ...

Ähnliche Inhalte
Batch & Shell
gelöst Powershell - In Textdatei suchen und ersetzen (5)

Frage von Raaja89 zum Thema Batch & Shell ...

Batch & Shell
gelöst 2 Csv -Dateien zum Teil zusammenfügen (6)

Frage von Piotrney zum Thema Batch & Shell ...

Batch & Shell
Mehrere.csv Dateien zusammenfügen zu einer Datei mit bat (4)

Frage von Piotrney zum Thema Batch & Shell ...

Heiß diskutierte Inhalte
Microsoft
Ordner mit LW-Buchstaben versehen und benennen (21)

Frage von Xaero1982 zum Thema Microsoft ...

Netzwerkmanagement
gelöst Anregungen, kleiner Betrieb, IT-Umgebung (18)

Frage von Unwichtig zum Thema Netzwerkmanagement ...

Windows Update
Treiberinstallation durch Windows Update läßt sich nicht verhindern (17)

Frage von liquidbase zum Thema Windows Update ...