connecthor
Goto Top

Inhalt einer txt auslesen und bei übereinstimmung Zeilen aus andered Datei einfügen

Hallo @all

ich hätte da ein kleines Problemchen--->

also ich hab da eine Datei in der ein Wert (z.b. [profil=0]) steht. Danach stehen noch ein paar andere Werte. Ich möchte danach noch weitere einträge einfügen. Das klappt schon.
Nun das echte Problem. Ich habe 2 unterschiedliche Einträge zu machen, je nach dem in welcher reihenfolge der user sich die Dateien installiert.

Hauptdatei <<<

[profil=0]
zeile1
zeile2
zeile3


dann soll sich der user ein programm installieren und in der Hauptdatei soll ein wert eingtragen werden wie folgt:

[profil=1]
zeile1
zeile2
zeile3

dann gibt es weitere programme die installiert werden können. Leider muss der Wert [profil] IMMER im Format
[profil=0]
...
[profil=1]
...
[profil=2]
...

vorliegen.

Was muss ich machen, um den schon installierten passus " [profil=*] auszulesen und bei weiteren installationen im richtigen format in der Datei zu hinterlegen??

Vielen Dank für eure Hilfe
Kommentar vom Moderator Biber am 05.04.2010 um 21:55:21 Uhr
Zwei klar vor- und ausgezeichnete Lösungsansätze - Beitrag auf "Beantwortet" gesetzt.

Content-ID: 139781

Url: https://administrator.de/forum/inhalt-einer-txt-auslesen-und-bei-uebereinstimmung-zeilen-aus-andered-datei-einfuegen-139781.html

Ausgedruckt am: 22.12.2024 um 03:12 Uhr

bastla
bastla 02.04.2010 um 20:34:23 Uhr
Goto Top
Hallo connecthor!

Ließe sich Deine Problemstellung auf "Finde die niedrigste noch nicht in '[profil=Zahl]' enthaltene Zahl!" reduzieren?

In diesem Fall etwa so:
@echo off & setlocal
set "Datei=D:\Die.ini"  
set /a Nr=0

:Loop
findstr /i /l "[profil=%Nr%]" "%Datei%">nul || goto :Found  
set /a Nr+=1
goto :Loop

:Found
set "Wert=[profil=%Nr%]"  
echo %Wert%
Grüße
bastla
77559
77559 04.04.2010 um 19:16:12 Uhr
Goto Top
Hallo Bastla,

mit nur einem findstr und Vergleich der Nr dürfte das doch effizienter sein.
(auch wenn das in diesem Fall egal ist)

@echo off & setlocal EnableDelayedExpansion
set "Datei=c:\Test\2010-04\Die.ini"  
Set Nr=0
For /f "tokens=2 delims=[=]" %%A in (  
  'findstr /i /l "[profil=" "%Datei%"'  
    ) Do If %%A GTR !Nr! Set Nr=%%A
set /a Nr+=1
set "Wert=[profil=%Nr%]"  
echo %Wert%

Gruß
LotPings

Edit: Anregung von Bastla eingearbeitet
bastla
bastla 04.04.2010 um 20:15:30 Uhr
Goto Top
Hallo LotPings!

Gute Idee face-smile, handwerklich fehlt allerdings "delayedExpansion" - es wird dadurch in der aktuellen Fassung immer "GTR 0" verglichen, was auch gut geht, wenn die Nummern innerhalb der ".ini"-Datei brav aufsteigend verwendet wurden; dann allerdings wäre der Vergleich überhaupt unnötig, und es müsste einfach die letzte vorkommende Nummer um 1 erhöht werden.

Eine Abwandlung davon - nämlich tatsächlich die ".ini" vorweg zu sortieren - würde aber daran scheitern, dass die Nummern keine feste Stellenanzahl haben.

Grüße
bastla
77559
77559 05.04.2010 um 17:46:46 Uhr
Goto Top
Zitat von @bastla:
Gute Idee face-smile, handwerklich fehlt allerdings "delayedExpansion"

Du hast ja sowas von Recht face-wink
Danke, habe es schon geändert

Ostergrüße
LotPings
connecthor
connecthor 08.04.2010 um 18:50:58 Uhr
Goto Top
Ja, so hab ich mir das gedacht. Profile=0 ist standard. hinzu sollen dann immer profile=1 usw. egal in welcher reichenfolge die programme installiert werden. ich werds mal gleich testen... danke schon mal im vorraus
connecthor
connecthor 13.04.2010 um 10:58:21 Uhr
Goto Top
ich habs jetzt... BASTLA hatte die beste (einzige lösung)
LotPings lösung war noch nicht ganz vollständig... es wurde das [profil=x] nicht um eins erhöht.

mein script sieht jetzt so aus:
set "User=%USERPROFILE%"
set "Datei=%USER%\anwendungsdaten\info.ini"
findstr /l "umb-storno" "%Datei%" && goto copy

set /a Nr=0
:Loop
set /a Nr+=1
goto :Loop

:Found
set "Wert=[profile%Nr%]"
echo. >> "%Datei%"
echo %Wert% >> "%Datei%"
more "d:\dazu.txt" >> "%Datei%"

:copy
...

vieken dank für eure hilfe jungs!!!!
77559
77559 13.04.2010 um 11:49:19 Uhr
Goto Top
Zitat von @connecthor:
ich habs jetzt... BASTLA hatte die beste (einzige lösung)
LotPings lösung war noch nicht ganz vollständig... es wurde das [profil=x] nicht um eins erhöht.

Protest,
entsprechend deinen Vorgaben funktioniert das hier.
Hast du den letzten Stand berücksichtigt?
Zeile 7 erhöht die höchste gefundene Profil Nr um eins.

Damit meine Variante auch bei leerer Datei funktioniert, könnte man noch Zeile 3 ändern in:
Set Nr=-1

Gruß
LotPings
connecthor
connecthor 15.04.2010 um 10:25:27 Uhr
Goto Top
hab dein script probiert...
leider hat er immer nur [profile=1] eingefügt... keine ahnung warum.
hast du das mal getestet???
77559
77559 15.04.2010 um 12:11:14 Uhr
Goto Top
Ja, ich habs nochmal getestet.
Einzige Änderung in Zeile 3 auf -1, (Der alte Beitrag lässt sich mehr editieren).

Ich vermute mal einen Übertragungsfehler - bitte "in den Speicher kopieren" oder Quelltext ansehen+kopieren.
Computer sind ja so schrecklich konsequent - tun genau das und nur das, was ihnen vorgegeben wird.

Gruß
LotPings
connecthor
connecthor 16.04.2010 um 09:29:21 Uhr
Goto Top
dann mach ich irgendwas falsch..
das [profil=0] ist standard.
bei dir wird doch nur soweit ich sehe der erste gefundene wert genommen und +1 gesetzt.
da ist dann egal welche werte da noch stehen... oder?!?!?!
77559
77559 16.04.2010 um 09:50:09 Uhr
Goto Top
Moin moin,

nein Zeile 4-6 ist eine Schleife die alle gefundenen "[profil="-Zeilem mit dem vorherigen Maximalwert vergleicht und ihn ggfs ersetzt.
Man kann diese 3 Zeilen auch ohne Änderung der Funktion hinereinander in eine Zeile schreiben, ich finde es so halt übersichtlicher.

Gruß
LotPings