Automatisch op tijd mail versturen via excel

Status
Niet open voor verdere reacties.

Jay305

Gebruiker
Lid geworden
6 nov 2018
Berichten
76
Goedendag,
ik ben even bezig geweest om een code in elkaar te zetten zodat ik op een bepaalde tijd 1 sheet te mailen naar mezelf.
ik heb nu deze code maar deze werkt niet, kan iemand me helpen?

Code:
Sub Mail_Sheet_Outlook_Body()

    Application.ReferenceStyle = xlA1
    Dim rng As Range
    Dim OutApp As Object
    Dim OutMail As Object
    
    With Application
        .EnableEvents = False
        .ScreenUpdating = False
    End With

    Set rng = Sheets("Blad1").UsedRange
    'You can also use a sheet name
    'Set rng = Sheets("YourSheet").UsedRange

    Set OutApp = CreateObject("Outlook.Application")
    Set OutMail = OutApp.CreateItem(0)

    On Error Resume Next
    With OutMail
        .To = "jay@meteorsystems.nl"
        .CC = ""
        .BCC = ""
        .Subject = "overdracht test mail"
        .HTMLBody = RangetoHTML(rng)
        .Send   'or use .Display
    End With
    On Error GoTo 0

    With Application
        .EnableEvents = True
        .ScreenUpdating = True
    End With

    Set OutMail = Nothing
    Set OutApp = Nothing
End Sub


Function RangetoHTML(rng As Range)
    Dim fso As Object
    Dim ts As Object
    Dim TempFile As String
    Dim TempWB As Workbook

    TempFile = Environ$("temp") & "" & Format(Now, "dd-mm-yy h-mm-ss") & ".htm"

    'Copy the range and create a new workbook to past the data in
    rng.Copy
    Set TempWB = Workbooks.Add(1)
    With TempWB.Sheets(1)
        .Cells(1).PasteSpecial Paste:=8
        .Cells(1).PasteSpecial xlPasteValues, , False, False
        .Cells(1).PasteSpecial xlPasteFormats, , False, False
        .Cells(1).Select
        Application.CutCopyMode = False
        On Error Resume Next
        .DrawingObjects.Visible = True
        .DrawingObjects.Delete
        On Error GoTo 0
    End With

    'Publish the sheet to a htm file
    With TempWB.PublishObjects.Add( _
         SourceType:=xlSourceRange, _
         Filename:=TempFile, _
         Sheet:=TempWB.Sheets(1).Name, _
         Source:=TempWB.Sheets(1).UsedRange.Address, _
         HtmlType:=xlHtmlStatic)
        .Publish (True)
    End With

    'Read all data from the htm file into RangetoHTML
    Set fso = CreateObject("Scripting.FileSystemObject")
    Set ts = fso.GetFile(TempFile).OpenAsTextStream(1, -2)
    RangetoHTML = ts.readall
    ts.Close
    RangetoHTML = Replace(RangetoHTML, "align=center x:publishsource=", _
                          "align=left x:publishsource=")

    'Close TempWB
    TempWB.Close savechanges:=False

    'Delete the htm file we used in this function
    Kill TempFile

    Set ts = Nothing
    Set fso = Nothing
    Set TempWB = Nothing
End Function

Sub Workbook_Open()
       Application.OnTime TimeValue("14:10:00"), "Blad2.Mail_Sheet_Outlook_Body"
End Sub
 
Laatst bewerkt:
Plaats je code in codetags.
"Werkt niet" is een kreet waar me niets mee kunnen.
Krijg je een foutmelding of zo?
 
er gebeurt niks wanneer deze tijd komt dus in mijn beeld: werkt niet, maar mijn vraag is meer hoe krijg ik dit dan wel werkend.
 
Er staan nog geen codetags om je code.
Ook zie ik nergens een Timer code om de functie op een bepaalde tijd te starten.
 
code tags zijn geregeld, sorry ik doe dat niet vaak.
Deze timer code, hoe bedoel je dat en hoe moet ik deze verwerken?
 
Ik begreep uit je eerste post dat je dat automatisch op een ingesteld tijdstip wilt laten gebeuren?
 
Maar hoe heb je dat ingericht dan?
De code die je plaatste verzorgt alleen het mailen.
Er staat geen code in die dat vanzelf op een ingestelde tijd gaat doen.
 
Dat is meer mijn vraag, hoe stel ik deze code samen.
ik heb zelf wat geprobeerd bij de laatste paar zinnen maar dit werkt niet.
Het werkt nu met een knop.
 
Ok. Dus terwijl je in het document aan het werk bent wil je dat om de zoveel tijd automatisch die mail wordt verstuurd?
Ik stel iedere keer weer een vraag, maar dat komt omdat er nogal wat mogelijkheden zijn.
Wees dus precies in de uitleg van wat je bedoeling is.
 
Laatst bewerkt:
ik heb een ander bestand waarmee we op het werk overdrachten zetten, hier is een pagina die alles verzameld van die dag.
deze info wil ik aan de eind van de dag automatisch versturen als mail naar mijn baas als zijnde overdracht van die dag.
dit zal dan om kwart voor 12 zijn na de avond shift.
 
Maar heb je dan dat document open in Excel?
Of moet de computer dat volledig automatisch doen, ook als niemand dat document in Excel open heeft?
 
Ik ga ervan uit dat je mail code werkt, daar je aangeeft dat het werkt met een knop.
Dit stukje code moet je in de ThisWorkbook sectie zetten.
Code:
Sub Workbook_Open()
       Application.OnTime TimeValue("14:10:00"), "Blad2.Mail_Sheet_Outlook_Body"
End Sub
De rest in een gewone module.
Je zal het stukje code ook moeten veranderen in
Code:
Sub Workbook_Open()
       Application.OnTime TimeValue("14:10:00"), "[COLOR="#FF0000"]Mail_Sheet_Outlook_Body[/COLOR]"
End Sub
Omdat je de macro die de mail verstuurt zo hebt genoemd.
 
Dat zal prima werken, maar alleen als dat document in Excel is geopend.
 
het moet eigenlijk gebeuren wanneer de shift voorbij is dus wanneer de pc uitstaat, maar dat gaat niet werken denk ik?
 
Nee, een computer doet niks als deze uit staat.
 
logisch haha, het staat wel op een server dit constant draait. kan ik daar iets mee of zal ik echt constant de pc aan moeten hebben en excel geopend?
 
Dat zal je dat proces op de server moeten inrichten en gebruik maken van de Windows Task Scheduler.
Deze kan dan een batch file starten om een bepaalde tijd die dan het document in Excel opent en de taak uitvoert.
Op die server moet dan uiteraard ook Office zijn geïnstalleerd.
 
Laatst bewerkt:
oké, dit ga ik uitzoeken en proberen. maar in ieder geval enorm bedankt!
 
Laat maar weten als je er vragen over hebt.
 
Status
Niet open voor verdere reacties.
Steun Ons

Nieuwste berichten

Terug
Bovenaan Onderaan