er.zet
Goto Top

Per Batch Zeichenfolgen suchen und mit nachfolgende Zeichen in neue Datei kopieren

Hallo! Die Fragestellung entspricht zwar einigen bereits gestellten hier im Forum. Leider komme ich nach mehreren Stunden recherchieren und probieren nicht so recht klar. Für Euch Experten ist das sicher kein Problem.

Ich habe mehrere Dateien "Ein?.dat" in einem Verzeichnis. Dort liegt auch die zu erstellende "vis.bat". Diese soll alle "Ein?.dat" nach einer Zeichenkette "visval" durchsuchen. Die Zeichenkette und die folgenden 11 Zeichen sollen fortlaufend in ein eine einzige neue Datei "Aus.dat" kopiert werden. Vielen Dank schon mal!

Ein1.dat
Ein2.dat
Ein3.dat
...

Ein1.dat ... Ein?.dat sieht immer so aus:
// Datafile written by Mathcad
// 08/10/11 13:57:18

.MATRIX 0 0 24 3
 "visval,10000,58.1228600192828"              0              0  
 "visval,10001,55.8719565435609"              0              0  
 "visval,10002,45.8351180157297"              0              0  
 "visval,10003,58.5046416119181"              0              0  
 "visval,10004,57.6494541912281"              0              0  
 "visval,10005,45.7315176626331"              0              0  
 "visval,10006,37.2643068652701"              0              0  
 "visval,10007,26.1210065954005"              0              0  
 "visval,10008,22.7099962321111"              0              0  
 "visval,10009,25.0559360319937"              0              0  
 "visval,10010,35.9036309867422"              0              0  
 "visval,10011,31.333264310119"              0              0  
 "visval,10012,89.2226372546821"              0              0  
 "visval,10013,85.4817205754242"              0              0  
 "visval,10014,81.3341356276671"              0              0  
 "visval,10015,86.6759720331076"              0              0  
 "visval,10016,82.8176312808791"              0              0  
 "visval,10017,78.5943078843083"              0              0  
 "visval,10018,52.3241633904348"              0              0  
 "visval,10019,53.1341030066508"              0              0  
 "visval,10020,53.1207010124104"              0              0  
 "visval,10021,50.3795769037556"              0              0  
 "visval,10022,55.0316549690835"              0              0  
 "visval,10023,58.3320021304807"              0              0  

Aus.dat sollte dann so aussehen:
visval,10000,58.1
visval,10001,55.8
visval,10002,45.8
visval,10003,58.5
visval,10004,57.6
visval,10005,45.7
...

Content-Key: 171322

Url: https://administrator.de/contentid/171322

Ausgedruckt am: 29.03.2024 um 14:03 Uhr

Mitglied: Skyemugen
Skyemugen 11.08.2011 um 10:35:31 Uhr
Goto Top
Aloha,

1.) Ohne Hallo und ohne Gruß wird hier nicht mehr bedient.
2.) 55.87 wird wirklich zu 55.8 und nicht zu 55.9?

greetz André
Mitglied: bastla
bastla 11.08.2011 um 11:06:08 Uhr
Goto Top
@Skyemugen
55.87 wird wirklich zu 55.8 und nicht zu 55.9?
Wegen
die folgenden 11 Zeichen ...
Überlegungen zur Sinnhaftigkeit soll der TE anstellen ...

Grüße
bastla
Mitglied: er.zet
er.zet 11.08.2011 um 11:06:44 Uhr
Goto Top
Hallo André,

1. Ich gelobe Besserung!
2. Runden ist nicht notwendig.

Grüße Robert
Mitglied: Skyemugen
Skyemugen 11.08.2011 um 11:19:39 Uhr
Goto Top
Aloha Robert,

nun dein Beispiel hat, wie bastla bereits gemerkt hat, keine 11 Zeichen ...

aber egal, arbeiten wir erst einmal mit einer Stelle nach dem Punkt und max. zweistelligen Nummerierungen
@echo off & setlocal
set "Pfad=E:\Skripte"  
pushd "%Pfad%"  
set "Output=Aus.dat"  
if exist "%Output%" del "%Output%"  
for /f "delims=" %%s in ('dir /b "Ein??.dat"') do (  
for /f "tokens=2-4 delims=,. " %%m in ('findstr "visval" "%%s"') do call :Ablauf %%m %%n "%%o  
)
popd
pause
exit /b

:Ablauf
set "Zahl=%~3"  
set "Zahl=%Zahl:~0,1%"  
>>"%Output%" echo visval,%1,%2.%Zahl%  
goto :eof


Achso, momentan werden Aus?.dat equivalent zur Ein?.dat erstellt, da mir unklar ist, ob du alle in eine haben willst oder für jede eine einzelne Datei.

greetz André

edit: jetzt mit DEP für del !Output! und für Ein- bis N-stelligen Dezimalzahlen
edit²: jetzt einer für alle und ganz korrekt mit gerader Anzahl Zollzeichen
Mitglied: er.zet
er.zet 11.08.2011 um 11:39:38 Uhr
Goto Top
Tiptop! Danke! Was muss geändert werden, damit alle Ein??.dat in eine Aus.dat generiert werden?
Mitglied: bastla
bastla 11.08.2011 um 11:44:06 Uhr
Goto Top
@Skyemugen
nun dein Beispiel hat, wie bastla bereits gemerkt hat, keine 11 Zeichen ...
Mitnichten - nach "visval" folgen mit ",10000,58.1" tatsächlich 11 Zeichen.
Da Du (zu Recht) gerne mal eine gerade Anzahl von "Zollzeichen" urgierst, wäre eigentlich
for /f "tokens=2-4 delims=,. " %%m in ('findstr "visval" "%%s"') do call :Ablauf %%m %%n "%%o
und entsprechend
set "Zahl=%~3"
exakter ...

Grüße
bastla
Mitglied: Skyemugen
Skyemugen 11.08.2011 um 11:47:51 Uhr
Goto Top
Aloha,

code wurde dahingehend geändert.

greetz André
Mitglied: Skyemugen
Skyemugen 11.08.2011 um 11:49:24 Uhr
Goto Top
Aloha bastla,

stimmt, das erste Komma hatte ich lustigerweise ignoriert delims im Kopf ;D zum Anderen: Joa, genau genommen kam mir das auch in den Sinn, ich fand es aber erst unschön aber man sollte schon strikt bei seinen Prinzipien bleiben, also ist es wieder drin face-wink

greetz André

P.S.: Aber dieser drollige bug, dass Ein??.dat equ Ein1.dat sein kann, ist immer wieder kurios face-wink Aber lässt sich hier vorteilhaft nutzen.
Mitglied: bastla
bastla 11.08.2011 um 11:53:33 Uhr
Goto Top
@Skyemugen
-Die Zeilen 5 und 6 wären vor der Zeile 4 besser aufgehoben ... [Edit] Ich habe schon wieder die 5 "Editierminuten" nicht berücksichtigt. face-wink [/Edit]
Wieso "bug" - ist doch sicher ein "feature" ... face-wink

Grüße
bastla
Mitglied: Skyemugen
Skyemugen 11.08.2011 um 11:54:15 Uhr
Goto Top
Aloha bastla,

:P too late, war längst geschehen face-wink kommt davon, wenn man mal so, dann so, dann DEP, dann doch alles in einem, da ändert man und lässt es erst einmal da stehen, wo es war ^_^

greetz André

edit: so kann das gehen *fg* war aber knapp face-wink

P.S.: Klar, bei M$ ist alles Seltsame immer ein feature, darum ist es ja so kostengünstig face-wink
P.P.S: @bastla, hattest du gemerkt: auch hier kam anfangs erst wieder call set zum Einsatz *gg*
Mitglied: er.zet
er.zet 11.08.2011 um 11:59:26 Uhr
Goto Top
Vielen Dank. Klappt alles bestens!