Top-Themen

AppleEntwicklungHardwareInternetLinuxMicrosoftMultimediaNetzwerkeOff TopicSicherheitSonstige SystemeVirtualisierungWeiterbildungZusammenarbeit

Aktuelle Themen

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

CMD - gibt es eine datei im ordner wenn ja dann bitte als anhang senden

Frage Microsoft Windows Tools

Mitglied: donald86

donald86 (Level 1) - Jetzt verbinden

23.09.2010, aktualisiert 17:37 Uhr, 4187 Aufrufe, 8 Kommentare

Hallo leute ich mache gerade eine CMD-Datei und habe das Problem das ich die dateien nicht einzeln auslesen kann ( datei für datei). ich habe es mit for und mit if exist schleifen versucht aber irgendwie kam ich nicht weiter.

Ziel ist es das für jede Datei einzeln welche im "ausgangs" ordner landet eine email gesendet wird (per Blat) und sie danach in den ordner "versendet" geschoben wird. wenn keine dateien mehr vorhanden sind ist das Script fertig.

mein Beispiel bis jetzt:

ich habe einen Ordner Ausgang mit folgendem Inhalt
-tabelle1.xlsx
-tabelle2.xlsx
-tabelle3.xlsx
-text.txt
-word.docx

und einen versendet Ordner ohne inhalt

und mein CMD Script :

:START
REM Abfrage gibt es überhaupt Dateien in Ausgangsordner?
if exist C:Pfad\ausgang\*.xlsx goto SEND_EXCEL
if exist C:Pfad\ausgang\*.txt goto SEND_TXT
if exist C:Pfad\ausgang\*.docx goto SEND_WORD
goto ENDE

REM Datei im Email senden und in Versendet - Ordner verschieben + Loop
:SEND_EXCEL
Blat -install Host. meine@email.ch
Blat "C:Pfad\body.txt" -to meine@email.ch -server smtp.server.ch -attach "C:Pfad\ausgang\*.xlsx" -debug -timestamp -log blatSMTPlog.txt -subject "Blat Email-Test Excel"
move C:Pfad\ausgang\*.xlsx C:Pfad\versendet
goto START

:SEND_TXT
Blat -install Host. meine@email.ch
Blat "C:Pfad\body.txt" -to meine@email.ch -server smtp.server.ch -attach "C:Pfad\ausgang\*.txt" -debug -timestamp -log blatSMTPlog.txt -subject "Blat Email-Test TEXT"
move C:Pfad\ausgang\*.txt C:Pfad\versendet
goto START

:SEND_WORD
Blat -install Host. meine@email.ch
Blat "C:Pfad\body.txt" -to meine@email.ch -server smtp.server.ch -attach "C:Pfad\ausgang\*.docx" -debug -timestamp -log blatSMTPlog.txt -subject "Blat Email-Test WORD"
move C:Pfad\ausgang\*.docx C:Pfad\versendet
goto START


REM Script Springpunkt um Das Script ohne Aktion zu Beenden
:ENDE
exit


Mit diesem Beispiel bekomme ich aber drei Emails und zwar für jeden Dokumenten typ eine. leider werden aber z.b. die Excel tabellen zusammen genommen und in einem Email geschickt diese sollten aber auch einezeln in seperaten emails versendet werden.

danke für die Hilfe gruss Donald
Mitglied: 60730
23.09.2010 um 18:10 Uhr
servus,

das könnte man so umschreiben:
(allerdings auch das ganze noch weiter "eindampfen" - doppelte / dreifache Befehlszeilen, wo nur eine "Variable" variabel ist - kann man schöner bauen)

01.
:START 
02.
REM Abfrage gibt es überhaupt Dateien in Ausgangsordner? 
03.
if exist C:\Pfad\ausgang\*.xlsx for %%a in (C:\Pfad\ausgang\*.xlsx) do ( 
04.
                         call :SEND_mail "Blat Email-Excel" 
05.
                         move C:\Pfad\ausgang\%%a C:\Pfad\versendet 
06.
07.
if exist C:\Pfad\ausgang\*.txt  for %%a in (C:\Pfad\ausgang\*.txt) do ( 
08.
                         call :SEND_mail "Blat Email-Test TEXT" 
09.
                         move C:\Pfad\ausgang\%%a C:\Pfad\versendet 
10.
11.
if exist C:\Pfad\ausgang\*.docx  for %%a in (C:\Pfad\ausgang\*.docx) do ( 
12.
                        call :SEND_mail "Blat Email-Test WORD" 
13.
                        move C:\Pfad\ausgang\%%a C:\Pfad\versendet 
14.
15.
goto ENDE 
16.
 
17.
REM Datei im Email senden und in Versendet - Ordner verschieben + Loop 
18.
:SEND_mail 
19.
Blat -install Host. meine@email.ch 
20.
Blat "C:\Pfad\body.txt" -to meine@email.ch -server smtp.server.ch -attach "C:\Pfad\ausgang\%%a" -debug -timestamp -log blatSMTPlog.txt -subject %1 
21.
goto eof 
22.
 
23.
REM Script Springpunkt um Das Script ohne Aktion zu Beenden 
24.
:ENDE 
25.
exit
ungetestet...und ein paar von dir fehlende \ immer bei C:\Pfad\ ergänzt

Gruß

edit: @bastla

  • isch hätt jetzt mal das /f us däm Schläyffsche ruusjetan abba wat de mir mit de if exischd vertelle mägst hädd isch nüschd jerafft
sorry aber isch hädd grad nen Kaffe mit CMH jeteilt und bin noch jaanz uffjedräht..
Bitte warten ..
Mitglied: bastla
23.09.2010 um 18:23 Uhr
Hallo donald86 und willkommen im Forum, hallo T-Mo!

Nur als Denkanstoß hinsichtlich des "if exist": Der "do"-Teil der Schleife
for %%a in ("C:\Pfad\ausgang\*.xlsx") do
wird für jede gefundene xlsx-Datei einmal ausgeführt - daher wie oft, wenn keine gefunden wird?

Grüße
bastla

[Edit] @T-Mo: OK, Auflösung : Das "if exist" ist hier schlicht überflüssig, da, wenn es keine xlsx-Dateien gibt, die Schleife ohnehin gleich wieder verlassen wird. [/Edit]
Bitte warten ..
Mitglied: donald86
24.09.2010 um 08:07 Uhr
Wenn keine datei gefunden wird soll das script sich beenden wäre die idee.

Ich würde das Script dan mehrmals pro tag laufen lassen usw
Bitte warten ..
Mitglied: donald86
24.09.2010 um 08:19 Uhr
hey super timo 5 emails bekomme ich nun - einziger fehler noch das attachment kommt nicht mit und die daten werden nicht gemovet.

siegt so aus als wäre das %%a für das script irgendwie nichts handfestes
Bitte warten ..
Mitglied: bastla
24.09.2010 um 08:26 Uhr
Hallo donald86!
Wenn keine datei gefunden wird soll das script sich beenden wäre die idee.
Dein "goto ENDE" sorgt ja ohnehin dafür ...
Um tatsächlich für jede einzelne Datei eine eigene Mail zu erhalten, könnte das Ganze (ungetestet) eher so aussehen:
01.
:START 
02.
Blat -install Host. meine@email.ch 
03.
 
04.
for %%a in (C:\Pfad\ausgang\*.xlsx) do ( 
05.
    call :SEND_mail "Blat Email-Excel" "%%a" 
06.
    move "%%a" "C:\Pfad\versendet\" 
07.
08.
for %%a in (C:\Pfad\ausgang\*.txt) do ( 
09.
    call :SEND_mail "Blat Email-Test TEXT" "%%a" 
10.
    move "%%a" "C:\Pfad\versendet\" 
11.
12.
for %%a in (C:\Pfad\ausgang\*.docx) do ( 
13.
    call :SEND_mail "Blat Email-Test WORD" "%%a" 
14.
    move "%%a "C:\Pfad\versendet\" 
15.
16.
goto ENDE 
17.
 
18.
REM Datei im Email senden und in Versendet - Ordner verschieben + Loop 
19.
:SEND_mail 
20.
Blat "C:\Pfad\body.txt" -to meine@email.ch -server smtp.server.ch -attach %2 -debug -timestamp -log blatSMTPlog.txt -subject %1 
21.
goto :eof 
22.
 
23.
REM Script Springpunkt um Das Script ohne Aktion zu Beenden 
24.
:ENDE 
25.
::exit ist unnötig
Grüße
bastla
Bitte warten ..
Mitglied: donald86
24.09.2010 um 08:36 Uhr
Das ist es Bastlaaa YEAAA!!!

Ihr seid doch ali "GAILI SIECHEEE "

CH-Deutsch für Coole jungs

Danke viel mal
Bitte warten ..
Mitglied: donald86
24.09.2010 um 08:38 Uhr
p.s. wofür steht jetz den das "for %%a" genau?
Bitte warten ..
Mitglied: bastla
24.09.2010 um 12:27 Uhr
Hallo donald86!
wofür steht jetz den das "for %%a" genau?
Damit wird jede zum Muster in der Klammer passende Datei (mit ihrem vollständigen Pfad) als "%%a" zur Verfügung gestellt - es kann aber nur im "do"-Teil der Schleife unter dieser Variablen darauf zugegriffen werden, weshalb sie beim Aufruf des Unterprogramms ":SEND_mail" als (zweiter) Parameter übergeben (und in ":SEND_mail" als %2 übernommen) werden muss ...

Mehr dazu: for /?

Grüße
bastla
Bitte warten ..
Neuester Wissensbeitrag
Ähnliche Inhalte
Windows 10
gelöst Unter Windows 10 Datei,Ordner INFO Fenster (5)

Frage von It-ogut zum Thema Windows 10 ...

Batch & Shell
Ordner erstellen ll Datei hinein kopieren (1)

Frage von heyalice zum Thema Batch & Shell ...

Heiß diskutierte Inhalte
Windows Userverwaltung
Ausgeschiedene Mitarbeiter im Unternehmen - was tun mit den AD Konten? (22)

Frage von patz223 zum Thema Windows Userverwaltung ...

Viren und Trojaner
Aufgepasst: Neue Ransomware Goldeneye verbreitet sich rasant (20)

Link von Penny.Cilin zum Thema Viren und Trojaner ...

LAN, WAN, Wireless
FritzBox, zwei Server, verschiedene Netze (19)

Frage von DavidGl zum Thema LAN, WAN, Wireless ...

Windows Netzwerk
Windows 10 RDP geht nicht (18)

Frage von Fiasko zum Thema Windows Netzwerk ...