viking
Goto Top

Dateinamen einer Textdatei aus der ersten Zeile erzeugen und zusätzlich Datei kopieren

Hallo, wieder mal eine kleine Frage.

Ich möchte per batch eine TXT Datei umbenennen, 2 mal an anderen Ort kopieren und Ursprungsdatei löschen.
Es sollen beide neuen Dateien auf in ein anderes Verzeichnis abgelegt werden, wobei der neue Name der Inhalt der ersten Zeile der Ursprungsdatei sein soll.
Einmal soll die Endung txt sein, einmal csv.
Beispiel:
Die Datei hat ursprünglich den Namen Test.txt und liegt auf C:\Temp\
Die erste Zeile der mehrzeiligen Datei hat den Inhalt "Mayer"
Nun sollen die neuen Dateien
Mayer.txt und Mayer.csv lauten und auf C:\Test\ gespeichert werden.
Die Ursprungsdatei soll auf C:\Temp soll gelöscht werden.

Wie kann man das lösen?

Gruß viking

Content-Key: 148540

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

Printed on: April 24, 2024 at 04:04 o'clock

Member: pieh-ejdsch
pieh-ejdsch Aug 07, 2010 at 07:17:14 (UTC)
Goto Top
Moin viking,
hier als ausfühlicher Batch
setlocal
set "Dateiordner=C:\Temp"  
set Datei="Test.txt"  
set "1stOrdner=C:\Test"  
set "1stExt=.txt"  
set "2ndExt=.csv"  
pushD "%DateiOrdner%"  
for %%i in (%Datei%) do (set /p Zeile=<"%%~i"  
	set Name="%%~i"  
	setlocal enabledelayedexpansion
	copy !Name! "!1stOrdner!\!Zeile!!1stExt!"  
	copy !Name! "!1stOrdner!\!Zeile!!2ndExt!"  
	del !Name!
	endlocal
)
popD

Edit 2. Ordner entfernt /Edit
[Edit2]Batch Korrigiert - Ein Anführungszeichen entfernt[/Edit2]
Gruß Phil
Member: bastla
bastla Aug 07, 2010 at 09:11:56 (UTC)
Goto Top
@ph
Eigentlich ist die Schleife für eine einzelne Datei etwas überdimensioniert - so würde es mE auch reichen:
@echo off & setlocal
set Datei="C:\Temp\Test.txt"  
set "Ziel=C:\Test"  
set "Ext1=.txt"  
set "Ext2=.csv"  
set /p Neu=<"%Datei%"  
copy "%Datei%" "%Ziel%\%Neu%%Ext1%">nul && move "%Datei%" "%Ziel%\%Neu%%Ext2%"  
Grüße
bastla
Member: it-frosch
it-frosch Aug 07, 2010 at 12:42:27 (UTC)
Goto Top
@bastla,

sehr effektives Script. Genau deshalb lese ich hier!

schönes WE
it-frosch
Member: bastla
bastla Aug 07, 2010 at 13:26:59 (UTC)
Goto Top
[OT]
@it-frosch
Danke für die Blumen, und schön, wenn Du etwas damit anfangen kannst ... face-smile

Grüße
bastla
[/OT]
Member: viking
viking Aug 07, 2010 at 20:14:33 (UTC)
Goto Top
Hallo bastla,

tut wie gewünscht!
Danke viking
Member: viking
viking Aug 07, 2010 at 20:21:53 (UTC)
Goto Top
Zitat von @pieh-ejdsch:
Moin viking,
hier als ausfühlicher Batch
setlocal
> set "Dateiordner=C:\Temp"  
> set Datei="Test.txt"  
> set "1stOrdner=C:\Test"  
> set "1stExt=.txt"  
> set "2ndExt=.csv"  
> pushD "%DateiOrdner%"  
> for %%i in (%Datei%) do (set /p "Zeile=<"%%~i"  
> 	set Name="%%~i"  
> 	setlocal enabledelayedexpansion
> 	copy !Name! "!1stOrdner!\!Zeile!!1stExt!"  
> 	copy !Name! "!1stOrdner!\!Zeile!!2ndExt!"  
> 	del !Name!
> 	endlocal
> )
> popD

Edit 2. Ordner entfernt /Edit
Gruß Phil

Hallo Phil,

Deine Version klappt bei mir nicht. Es öffnet sich eine Dosbox, ...
bastlas version funktioniert.

Daher ist meine Frage gelöst.
Trotzdem Danke auch an Dich.

Gruß viking.