Bonjour tout le monde,
Voici un code que j'ai récupéré sur le net et qui marche très bien. J'ai des petits soucis à l'adapter à mon besoin (notamment la boucle en rouge dans le code).
Ce que je veux faire:
Dès que "Today - deadline = 5 jours" j'envoie un mail de rappel
Je ne comprends pas pourquoi lorsque je met "Today - deadline <= 5 jours" le code tourne mais ramène la valeur correspondant au i=10 de ma boucle (dernière valeur) et lorsque je met "Today - deadline = 5 jours" j'ai un probléme de SourceRange (il me dit que la source n'est pas une range...)
Je met également mon fichier en copie car peut-être pas évidant à comprendre sinon
En tout cas je vous remercie de jeter un petit coup d'oeil là-dessus
Deux autres questions :
-est-ce que je peux mettre ce code dans un WorkBook SheetCalculate pour faire tourner ce code régulièrement?
- Comment faire pour qu'un seul mail soit envoyé même si la macro tourne plusieurs fois dans la journée et que la condition est encore vraie (ça sera gênant de spammer qqn plusieurs fois ds la journée pour un même rappel!)
Merci d'avance de me dire ce que vous en pensez
Voici un code que j'ai récupéré sur le net et qui marche très bien. J'ai des petits soucis à l'adapter à mon besoin (notamment la boucle en rouge dans le code).
Ce que je veux faire:
Dès que "Today - deadline = 5 jours" j'envoie un mail de rappel
Je ne comprends pas pourquoi lorsque je met "Today - deadline <= 5 jours" le code tourne mais ramène la valeur correspondant au i=10 de ma boucle (dernière valeur) et lorsque je met "Today - deadline = 5 jours" j'ai un probléme de SourceRange (il me dit que la source n'est pas une range...)
Je met également mon fichier en copie car peut-être pas évidant à comprendre sinon
En tout cas je vous remercie de jeter un petit coup d'oeil là-dessus
Deux autres questions :
-est-ce que je peux mettre ce code dans un WorkBook SheetCalculate pour faire tourner ce code régulièrement?
- Comment faire pour qu'un seul mail soit envoyé même si la macro tourne plusieurs fois dans la journée et que la condition est encore vraie (ça sera gênant de spammer qqn plusieurs fois ds la journée pour un même rappel!)
Merci d'avance de me dire ce que vous en pensez
Sub Mail_Range()
'Working in 2000-2010
Dim Source As Range
Dim Dest As Workbook
Dim wb As Workbook
Dim TempFilePath As String
Dim TempFileName As String
Dim FileExtStr As String
Dim FileFormatNum As Long
Dim OutApp As Object
Dim OutMail As Object
Dim Strbody As String
Dim calcul As Long
Set Source = Nothing
On Error Resume Next
For i = 2 To 10
calcul = (Int(today) - Int(Cells(i, 9)))
If calcul = 5 Then
Set Source = Range(Cells(i, 9), Cells(i, 9)).SpecialCells(xlCellTypeVisible)
Strbody = "type intervention : " & Cells(i, 4).Value & vbCrLf
End If
On Error GoTo 0
If Source Is Nothing Then
MsgBox "The source is not a range or the sheet is protected, " & _
"please correct and try again.", vbOKOnly
Exit Sub
End If
Next i
With Application
.ScreenUpdating = False
.EnableEvents = False
End With
Set wb = ActiveWorkbook
Set Dest = Workbooks.Add(xlWBATWorksheet)
Source.Copy
With Dest.Sheets(1)
.Cells(1).PasteSpecial Paste:=8
.Cells(1).PasteSpecial Paste:=xlPasteValues
.Cells(1).PasteSpecial Paste:=xlPasteFormats
.Cells(1).Select
Application.CutCopyMode = False
End With
TempFilePath = Environ$("temp") & "\"
TempFileName = "Selection of " & wb.Name & " " _
& Format(Now, "dd-mmm-yy h-mm-ss")
If Val(Application.Version) < 12 Then
'You use Excel 2000-2003
FileExtStr = ".xls": FileFormatNum = -4143
Else
'You use Excel 2007-2010
FileExtStr = ".xlsx": FileFormatNum = 51
End If
Set OutApp = CreateObject("Outlook.Application")
Set OutMail = OutApp.CreateItem(0)
With Dest
.SaveAs TempFilePath & TempFileName & FileExtStr, _
FileFormat:=FileFormatNum
On Error Resume Next
With OutMail
.To = "julien.xxx@xxx.fr"
.CC = ""
.BCC = ""
.Subject = "Intervention en cours"
.Body = Strbody
'.Attachments.Add Dest.FullName
'You can add other files also like this
'.Attachments.Add ("C:\test.txt")
.Send 'or use .Display
End With
On Error GoTo 0
.Close SaveChanges:=False
End With
Kill TempFilePath & TempFileName & FileExtStr
Set OutMail = Nothing
Set OutApp = Nothing
With Application
.ScreenUpdating = True
.EnableEvents = True
End With
End Sub
Pièces jointes
Dernière édition: