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 In Textdatei zeilenweise ein Zeichen ersetzen und csv-Datei erzeugen

Mitglied: watchdogg

watchdogg (Level 1) - Jetzt verbinden

15.02.2009, aktualisiert 17.02.2009, 9320 Aufrufe, 4 Kommentare

Hallo Leute,
ich bin neu im Forum und noch relativ unerfahren in Sachen Batch Dateien.

Ich habe eine Textdatei mit mehreren hundert Zeilen in folgendem Format (Pipes sind nur als Spaltentrenner eigefügt):

00148 | 81.7 | 5.4 | 9.2 | 7.2 | 0.5 | 1.5 | 42 | 0 | 265 | 80.00 | 04:57:27 | 05:06:38 | 8 | 1001510 RA | 12.02.2009

1.Problem: Die 0 in Spalte 9 soll in jeder Zeile in eine 1 umgewandelt werden. Aber nur diese 0, die anderen nicht.
Mein Versuch über eine Zeichenkette in der Art: " 0 " -> " 1 ". klappt nicht. Hier der Code:

for /F "delims=" %%a in (quelle.txt) do (
set text=%%a
set text=text: 0 = 1 >>ziel.txt
)
Ist die Herangehensweise eigentlich richtig, oder gibt es andere Möglichkeiten?

2.Problem: Trennzeichen

Auf den ersten Blick scheinen sich Leerzeichen als Trenner anzubieten. Kann ich aber nicht nehmen weil Spalte 15 Leerzeichen enthalten kann und diese Spalte würde es mir ja auch trennen. Da ich diese Textdatei zeilenweise in eine Datenbank einlesen möchte, brauche ich aber eine Art CSV-Datei mit eindeutigen Trennzeichen.
Am liebsten wäre mir das Semikolon.

Lässt sich sowas per Batch realisieren, oder muss ich doch über Excel gehen?

Please Help ....?!?

[Edit Biber] Am 17.02.2009 auf "Gelöst" gesetzt. [/Edit]
Mitglied: blubberblase
15.02.2009 um 15:40 Uhr
Hier mal eine Loesung fuer dein Problem:

01.
for /F "tokens=1-9* delims=|" %%a in (quelle.txt) do ( 
02.
    if "%%i" equ " 0 " ( set temp= 1 ) else ( set temp=%%i) 
03.
    set temp=%%a^|%%b^|%%c^|%%d^|%%e^|%%f^|%%g^|%%h^|!temp!^|%%j 
04.
    ECHO !temp: ^| =;!>>ziel.txt 
05.
)
Ziele 02: ersetzen der 0 durch eine 1 in Spalte 9
Zeile 03: Zeile wieder zusammensetzen
Zeile 04: " | " durch ";" ersetzen und in Datei rausschreiben
Bitte warten ..
Mitglied: watchdogg
15.02.2009 um 20:31 Uhr
Danke erstmal an blubberblase,

Meine Quelldatei ist aber leider nicht mit Pipes als Trenner versehen, das hab ich nur zum verdeutlichen angegeben.
Meine Ausgangsdatei sieht so aus: http://anotherland.de/beispiel.txt.
Das macht das Problem schwieriger, oder? Denn die Spalten sind ja durch ein oder mehrere Leerzeichen getrennt.
Gibts dafür auch ne Lösung?

MfG watchdogg
Bitte warten ..
Mitglied: bastla
15.02.2009 um 22:16 Uhr
Hallo watchdogg und willkommen im Forum!
Das macht das Problem schwieriger, oder? Denn die Spalten sind ja durch ein oder mehrere Leerzeichen getrennt.
Eigentlich wird es einfacher, denn die Spalten sind zwar durch Leerzeichen getrennt, haben aber vor allem eine fixe Breite, anhand deren die Zerlegung erfolgen kann.

Unter der Annahme, dass in Spalte 9 immer eine "1" stehen soll, und dass die Leerzeichen bis zur Spalte 14 eigentlich nicht benötigt werden, könnte der Batch (welcher, ganz nebenbei, kein Beispiel für übertriebene Eleganz darstellt) so aussehen:
01.
@echo off & setlocal 
02.
set "Ein=D:\Ausgangsdatei.txt" 
03.
set "Aus=D:\Ergebnis.csv" 
04.
set "D=;" 
05.
 
06.
if exist "%Aus%" del "%Aus%" 
07.
for /f "usebackq delims=" %%i in ("%Ein%") do set "Z=%%i" & call :ProcessLine 
08.
goto :eof 
09.
 
10.
:ProcessLine 
11.
set "Zeile=%Z:~0,20%%D%%Z:~21,6%%D%%Z:~28,7%%D%%Z:~36,7%%D%%Z:~44,7%%D%%Z:~52,6%%D%%Z:~59,6%%D%%Z:~66,6%%D%1%D%%Z:~80,6%%D%%Z:~87,6%%D%%Z:~94,8%%D%%Z:~103,8%%D%%Z:~112,5%%D% 
12.
set "Zeile=%Zeile: =%" 
13.
set "Zeile=%Zeile%%Z:~118,15%%D%%Z:~134,8%%D%%Z:~143,7% 
14.
>>"%Aus%" echo %Zeile% 
15.
goto :eof
Das Trennzeichen für die neue Datei wird in Zeile 4 festgelegt.

Die Zeile 12 dient dazu, aus den ersten 14 Feldern alle enthaltenen Leerzeichen zu entfernen.

Soferne jede Zeile der Ausgangsdatei (wie in Deinem Beispiel) tatsächlich mit einem Leerzeichen beginnt, müsste in den Zeilen 11 und 13 jeder Wert nach einem "~" (=Startposition des Feldes) um 1 erhöht werden, also zB
set "Zeile=%Z:~1,20%%D%%Z:~22,6% ...
Grüße
bastla
Bitte warten ..
Mitglied: watchdogg
17.02.2009 um 07:18 Uhr
@bastla,

darf ich dich ab heute GOTT nennen.
Vielen Dank es funktioniert natürlich tadellos.

MfG watchdogg
Bitte warten ..
Ähnliche Inhalte
Batch & Shell
HTML Dateien per CSV erzeugen
gelöst Frage von RechtschreibungBatch & Shell2 Kommentare

Hallo ich hoffe Ihr könnt mir helfen. Ich kenne mich grundlegend mit Batch Befehlen aus, aber das übersteigt ein ...

Batch & Shell

Per Batch Zeichen in Textdatei durch zeilenumbruch ersetzen

Frage von CreamyCewieBatch & Shell3 Kommentare

Hallo, ich habe folgende textdatei (test.txt) "þUEBERþNþSKZþBELþVARTþ3þaaþ5 þacþL þadþ20150385#umbr# UEBERþNþBELDATER" ich brauche nun ein Batch-Script welches mir die gesamte TXT-Datei ...

Batch & Shell

CSV-Datei Komma durch Semikolon ersetzen

gelöst Frage von FalkITBatch & Shell8 Kommentare

Hi Zusammen, ich suche eine Möglichkeit in einer Komma getrennten CSV Datei alle Kommas die als Trenner dienen durch ...

VB for Applications

Textdatei zeilenweise nach Datum sortieren

gelöst Frage von GurkenhobelVB for Applications2 Kommentare

Hallo Gemeinde, mehrere umfangreiche Textdateien, in denen zeilenweise wichtige Daten und Termine eingetragen sind, sollen zeilenweise nach dem Datum ...

Neue Wissensbeiträge
Windows Server

Windows Server Backup schlögt Fehl -Lösung 2008-2016

Tipp von BiGnoob vor 1 StundeWindows Server

Hi zusammen , ich möchte gerne einen Lösungstipp abgeben für folgenden fehler: lösung ist folgende:

Humor (lol)
Telekom vs. O2 - 3:2
Erfahrungsbericht von the-buccaneer vor 14 StundenHumor (lol)2 Kommentare

Unglaublich aber wahr: Nachdem mein privater Anschluss am 19.04.18 auf VOIP und VDSL umgestellt wurde, hatte ich seitdem 1,5 ...

Batch & Shell

Windows 10 Heimnetzgruppe abgeschaft. Ein Script für einfache Netzwerk - Freigabe im Heimnetzwerk

Anleitung von treehe vor 16 StundenBatch & Shell3 Kommentare

Anleitung für eine einfache Netzwerkfreigabe unter Windows 10 Wie weiter hab mal ein kleines CMD - Script gebastelt. Womit ...

Verschlüsselung & Zertifikate

Efail die II - Warum SMime und PGP der Zeit hinterherhinken

Information von certifiedit.net vor 2 TagenVerschlüsselung & Zertifikate

Guten Morgen, nachdem der letzte Beitrag rege kommentiert wurde, die IT-Republik sich nun darüber streitet ob es nun ein ...

Heiß diskutierte Inhalte
Netzwerke
IP-Adresse am zweiten Domänencontroller fest vergeben - Server verschwunden
Frage von DanielG1974Netzwerke18 Kommentare

Ich hab ein Problem, was ich bisher noch nicht erlebt habe Ich habe erfolgreich einen zweiten Server mit ActiveDirectory ...

Windows Server
Windows Server 2012 - Update - Beim Booten bleibt der Server beim Windows Zeichen stehen
Frage von KeilbachWindows Server14 Kommentare

Hallo Zusammen, ich grüße euch, mein Name ist Michele. Ich bin hier ganz Neu - da ich einfach nicht ...

Windows Tools
Virtueller Drucker gesucht (Schnittstelle: USB oder Seriell)
Frage von chrisButterflyWindows Tools14 Kommentare

Hi, ich suche einen virtuellen Drucker, den ich über eine USB oder serieller Schnittstelle ansprechen kann. Dieser Drucker soll ...

Firewall
Sophos SG 125 nicht mehr erreichbar
Frage von GwaihirFirewall14 Kommentare

Hallo zusammen, ausgerechnet über die Feiertage stimmt etwas mit meiner Firmen-Firewall nicht. Es ist eine Sophos SG 125 und ...