anarchator
Goto Top

Batchfile, string mit findstr suchen und Dateiname erhalten, wo string vorkommt

Hi Leute,

habe in "c:\ordner" viele .json Dateien.
Mit folgendem Code kann ich prüfen, ob das aktuelle Tagesdatum enthalten ist, das wäre heute gemäß folgender Definition z. B. dann "2023-01-31"

set yyyymmdd=%date:~6,4%-%date:~3,2%-%date:~0,2%
findstr /m "%yyyymmdd%" c:\ordner\*.json  

Das funktioniert soweit. ABER:
Ich brauche für die weitere Verarbeitung eine Ausgabe von dem Dateinamen, in welchem der String gefunden wurde. Falls der String in mehreren Dateien gefunden wurde, am besten die neueste Datei.
Hat jemand einen Tipp?

Content-Key: 52508976157

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

Printed on: May 12, 2024 at 07:05 o'clock

Mitglied: 11078840001
Solution 11078840001 Jan 31, 2024 updated at 15:56:52 (UTC)
Goto Top
@echo off
set yyyymmdd=%date:~6,4%-%date:~3,2%-%date:~0,2%
for /f "delims=" %%a in ('findstr /lm "%yyyymmdd%" "c:\ordner\*.json"') do echo %%a  
Tutorial zur FOR-Schleife

Oder gleich mit der Kraft-Muschel
Get-ChildItem "c:\ordner\*.json" -File | sort LastWriteTime -Descending | Select-String -Pattern (Get-Date -F "yyyy-MM-dd") -SimpleMatch | select -First 1 -ExpandProperty Path  
Member: anarchator
anarchator Jan 31, 2024 at 16:00:23 (UTC)
Goto Top
funktioniert leider nicht ->
Der Befehl "findstr" ist entweder falsch geschrieben oder
konnte nicht gefunden werden.
Member: anarchator
anarchator Jan 31, 2024 at 16:04:00 (UTC)
Goto Top
vielen Dank auch für den Powershell-Code.
Ich würde es gerne ohne Powershell gelöst bekommen. Am liebsten hätte ich als Ergebnis eine Variable, welche als Wert den Dateinamen enthält, in welchem der gesuchte String vorkommt.
Mitglied: 11078840001
11078840001 Jan 31, 2024 updated at 16:12:27 (UTC)
Goto Top
funktioniert leider nicht ->
Klappt hier im Test ohne Probleme, hast du einen Fehler beim Kopieren oder Anpassen gemacht
Am liebsten hätte ich als Ergebnis eine Variable, welche als Wert den Dateinamen enthält, in welchem der gesuchte String vorkommt.
Einfach statt dem echo am Ende ein set mit deiner Variablen benutzen in %%a steht der Name ja ergo hast du ja eigentlich schon eine Variable 🙃.
........... do set "myvar=%%a"  
Member: anarchator
anarchator Jan 31, 2024 at 16:17:23 (UTC)
Goto Top
stimmt!

So funktioniert es:

@echo off
set yyyymmdd=%date:~6,4%-%date:~3,2%-%date:~0,2%
for /f "delims=" %%a in ('findstr /lm "%yyyymmdd%" "c:\ordner\*.json"') do echo %%a    
pause
Ergebnis ist dann:
c:\ordner\2024-01-31_11104.5.json

Du hast also recht, es funktioniert! TAUSEND DANK!
Mein Fehler war folgender: Ich wollte den Pfad über eine Variable laufen lassen:

path=c:\ordner

und dann

for /f "delims=" %%a in ('findstr /lm "%yyyymmdd%" "%path%\*.json"') do echo %%a    

Und das geht nicht. Muss den Pfad nicht unbedingt vorher über Variable definieren.
Mitglied: 11078840001
11078840001 Jan 31, 2024 updated at 16:19:59 (UTC)
Goto Top
path=c:\ordner
Autsch niemals den Namen path als Variable überscheiben ! Denk mal nach warum face-wink.
https://ekiwi-blog.de/19215/path-variable-in-windows-konfigurieren-und-b ...
Member: anarchator
anarchator Jan 31, 2024 at 16:25:02 (UTC)
Goto Top
oopsie, wie dumm von mir.
Alles klar!
Mitglied: 11078840001
Solution 11078840001 Jan 31, 2024 updated at 16:32:20 (UTC)
Goto Top
Ach ja noch vergessen, falls es mehrere Dateien gibt nimmt das hier immer die neueste (nach Dateidatum)
@echo off
set yyyymmdd=%date:~6,4%-%date:~3,2%-%date:~0,2%
set "ordner=c:\ordner"  
set "newest="  
for /f "delims=" %%a in ('dir /b /a-d /o-d "%ordner%\*.json"') do findstr /l "%yyyymmdd%" "%ordner%\%%a" >nul && (if not defined newest set "newest=%ordner%\%%a")  
echo %newest%
Member: anarchator
anarchator Jan 31, 2024 at 16:38:40 (UTC)
Goto Top
perfekt!
Letzte Frage:
Am Ende des ganzen soll die Datei hochgeladen werden, z. B. so:

winscp.com" /command "open ftp://%username%:%password%@%host%" "put %newest%" "exit"  

Das funktioniert auch. Aber natürlich wird die Datei so hochgeladen, wie sie eben heißt. Sie soll aber einen anderen Namen bekommen, sagen wir "datei.json".
Wie kann man das erzielen?
Mitglied: 11078840001
11078840001 Jan 31, 2024 updated at 16:43:48 (UTC)
Goto Top
Sie soll aber einen anderen Namen bekommen, sagen wir "datei.json".
https://winscp.net/eng/docs/scriptcommand_put

put <file> [ [ <file2> ... ] <directory>/[ <newname> ] ]

............ "put %newest% ./datei.json" "exit"  
Member: anarchator
anarchator Jan 31, 2024 at 16:45:33 (UTC)
Goto Top
sorry, ich bin da offenbar zu doof, das anzupassen. Kannst Du mir helfen, wie o. g. Zeile,
also:

winscp.com" /command "open ftp://%username%:%password%@%host%" "put %newest%" "exit"    

genau lauten muss, damit die Datei als "datei.json" hochgeladen wird, und nicht mit dem eigentlichen Dateinamen?
Mitglied: 11078840001
11078840001 Jan 31, 2024 updated at 16:48:45 (UTC)
Goto Top
Freitag ist erst übermorgen, steht doch oben! Das Ding da auf dem Hals hat im Normalfall eine Funktion face-big-smile
Member: erikro
erikro Jan 31, 2024 at 16:53:03 (UTC)
Goto Top
Moin,

Zitat von @abamakabra:
Get-ChildItem "c:\ordner\*.json" -File | sort LastWriteTime -Descending | Select-String -Pattern (Get-Date -F yyyyMMdd) -SimpleMatch | select -First 1 -ExpandProperty Path  

Warum so kompliziert?

get-childitem *.json -filter *$(get-date -format "yyMMdd")* -file  

gibt das gewünschte Ergebnis zurück. OK, muss noch auf die jüngste Datei gefiltert werden.

Liebe Grüße

Erik
Mitglied: 11078840001
11078840001 Jan 31, 2024 updated at 17:01:10 (UTC)
Goto Top
Warum so kompliziert?
Weil ich es so verstanden habe das das aktuelle Datum innerhalb der Dateien enthalten sein soll nicht im Dateinamen
das hat er ja mit
findstr /m "%yyyymmdd%" c:\ordner\*.json
im Ursprungspost schon gemacht, findstr sucht hier in den Dateien. Ob die Datumsangaben im Dateinamen dazu korrelieren kann nur er sagen, im Ursprungspost stand nicht das Datumsangaben im Dateinamen stehen.
Member: anarchator
Solution anarchator Jan 31, 2024 at 16:55:49 (UTC)
Goto Top
Ich danke euch allen vielmals, insbesondere Abamakabra!

Mein Problem ist damit zur vollsten Zufriedenheit gelöst! Hier nochmal mein abschließendes Batch:

@echo off
set host=mein.host.de
set username=meinftpuser
set password=meinpasswort
set yyyymmdd=%date:~6,4%-%date:~3,2%-%date:~0,2%
set "ordner=meinpfad"    
set "newest="    
for /f "delims=" %%a in ('dir /b /a-d /o-d "%ordner%\*.json"') do findstr /l "%yyyymmdd%" "%ordner%\%%a" >nul && (if not defined newest set "newest=%ordner%\%%a")    
"G:\Meine Ablage\!DoNotTouch!\winscp.com" /command "open ftp://%username%:%password%@%host%" "put %newest% ./test.json" "exit"  
Member: anarchator
anarchator Jan 31, 2024 at 17:10:34 (UTC)
Goto Top
hab doch noch eine Frage:
Angenommen, in keiner der Dateien findet sich der genannte String.
Dann soll der Upload mit winscp.com einfach geskipped werden.
Wie erzielt man das?
Mitglied: 11078840001
11078840001 Jan 31, 2024 updated at 17:29:44 (UTC)
Goto Top
Zitat von @anarchator:

hab doch noch eine Frage:
Angenommen, in keiner der Dateien findet sich der genannte String.
Dann soll der Upload mit winscp.com einfach geskipped werden.
Wie erzielt man das?

if not defined newest (
    echo Keine Datei gefunden
    goto :eof
)
Member: anarchator
anarchator Jan 31, 2024 at 18:54:25 (UTC)
Goto Top
mega! Das ist jetzt so genial, jetzt kann ich was saucooles bauen face-smile
Member: erikro
erikro Feb 01, 2024 at 08:07:41 (UTC)
Goto Top
Zitat von @abamakabra:

Warum so kompliziert?
Weil ich es so verstanden habe das das aktuelle Datum innerhalb der Dateien enthalten sein soll nicht im Dateinamen
das hat er ja mit
findstr /m "%yyyymmdd%" c:\ordner\*.json
im Ursprungspost schon gemacht, findstr sucht hier in den Dateien. Ob die Datumsangaben im Dateinamen dazu korrelieren kann nur er sagen, im Ursprungspost stand nicht das Datumsangaben im Dateinamen stehen.

Achso. Das habe ich anders verstanden.