Forum - Problèmes liés à mes codes mis à disposition - SendMail CDO


 2 membres
Connectés : ( personne )

  Sujet n° 804
le 11/04/2018 16:33
par possible924
 
visiteur

Bonjour,

Dans les deux dernières fonctions proposées, je ne vois pas comment attacher la pièce jointe

(J'espère que ma question est à la bonne place).

A plus

Pierre

  

Réponse n° 1
--------
le 11/04/2018 17:12
par 3Stone
 
Administrateur

Citation :

je ne vois pas comment attacher la pièce jointe

Voir juste la fonction au dessus !

AddAttachment ("c:/cheminfichier.ext")

Un peu de curiosité, que diable wink

Cordialement,

Pierre (3Stone)

  
Réponse n° 2
--------
le 12/04/2018 08:09
par possible924
 
visiteur

Je tente de comprendre,

J'aimerais me servir des deux dernières fonctions comme suggéré, mais je me pose la question comment faire pour l'attachement. dois faire ça :

'Si le serveur smtp par défaut n'est pas reconnu (clients mail non Microsoft), on pourra employer les fonctions ci-dessous.
Function SendMailCDO(Sender As String, Receiver As String, _
                      Subject As String, BodyText As String, _
                      PièceJointe As String)

    Dim Cdo_Message As New CDO.Message
    Set Cdo_Message.Configuration = GetSMTPServerConfig()
    
    With Cdo_Message
        .From = Sender
        .To = Receiver
        .Subject = Subject
        .TextBody = BodyText
        .addAttachment = PièceJointe
        .Send
    End With
    Set Cdo_Message = Nothing

End Function
Function GetSMTPServerConfig() As Object
    Dim Cdo_Config As New CDO.Configuration
    Dim Cdo_Fields As Object
    Set Cdo_Fields = Cdo_Config.Fields

    With Cdo_Fields
        .Item(cdoSendUsingMethod) = cdoSendUsingPort
        .Item(cdoSMTPServer) = "smtp.free.fr"
        .Item(cdoSMTPServerPort) = 25
        .Update
    End With

    Set GetSMTPServerConfig = Cdo_Config
    Set Cdo_Config = Nothing
    Set Cdo_Fields = Nothing

End Function

'Syntaxe:
'Call SendMailCDO("Sender", "Receiver", "Subject", "BodyText", "PièceJointe")

Merci par avance pour la réponse

Pierre

  
Réponse n° 3
--------
le 12/04/2018 08:13
par possible924
 
visiteur

Le problème est que :


Function SendMailCDO(Sender As String, Receiver As String, _
                      Subject As String, BodyText As String, _
                      PièceJointe As String)

    Dim Cdo_Message As New CDO.Message
    Set Cdo_Message.Configuration = GetSMTPServerConfig()
    
    With Cdo_Message
        .From = Sender
        .To = Receiver
        .Subject = Subject
        .TextBody = BodyText
        .addAttachment = PièceJointe
        .Send
    End With

'Syntaxe:
'Call SendMailCDO("Sender", "Receiver", "Subject", "BodyText", "PièceJointe")

.addAttachment = PièceJointe me revoie un message d'erreur : "Erreur de compilation, argument non facultatif"

  
Réponse n° 4
--------
le 12/04/2018 08:20
par possible924
 
visiteur

Mais peut être que cela devrait marcher :

Function SendMailCDO(Sender As String, Receiver As String, _
                      Subject As String, BodyText As String, _
                      PièceJointe As String)

    Dim Cdo_Message As New CDO.Message
    Set Cdo_Message.Configuration = GetSMTPServerConfig()
    
    With Cdo_Message
        .From = Sender
        .To = Receiver
        .Subject = Subject
        .TextBody = BodyText
        .addAttachment (PièceJointe)
        .Send
    End With
    Set Cdo_Message = Nothing

End Function

'Syntaxe:
'Call SendMailCDO("Sender", "Receiver", "Subject", "BodyText", "W:CheminMaFacture")

Je te souhaite une bonne journée Ici à Toulon, il fait un temps de chien

Pierre

  
Réponse n° 5
--------
le 13/04/2018 20:13
par 3Stone
 
Administrateur

Bonjour,

Avec la fonction suivante et en respectant ce qui est dit et expliqué, tu as une méthode qui fonctionne parfaitement et sans autres manipulations.

Cordialement,

Pierre (3Stone)

  
Réponse n° 6
--------
le 15/04/2018 10:01
par possible924
 
visiteur

Pierre,

Merci pour ce code.

J'ai toujours un problème avec l'attachement dans cette fonction :

Public PièceJointe As String

Private Function GetSMTPServerConfig() As Object
    Dim Cdo_Config As New CDO.Configuration
    Dim Cdo_Fields As Object
    Set Cdo_Fields = Cdo_Config.Fields

    With Cdo_Fields
        .Item(cdoSendUsingMethod) = cdoSendUsingPort
        .Item(cdoSMTPServer) = DFirst("SMTP_Serveur", "T_Constantes")
        .Item(cdoSMTPServerPort) = DFirst("SMTP_Serveur_Port", "T_Constantes")
        .Update
    End With

    Set GetSMTPServerConfig = Cdo_Config
    Set Cdo_Config = Nothing
    Set Cdo_Fields = Nothing

End Function

Private Function SendMailCDO(Sender As String, Receiver As String, _
                      Subject As String, BodyText As String, PièceJointe)

    Dim Cdo_Message As New CDO.Message
    Set Cdo_Message.Configuration = GetSMTPServerConfig()
    
Sender = DFirst("Email_Expéditeur", "T_Constantes")
BodyText = DFirst("Corps_Message", "T_Constantes")

    With Cdo_Message
        .From = Sender
        .To = "pierre@foucaud.com"
        .Subject = Subject
        .TextBody = BodyText
        .addAttachment ("W:BasesIrisFacturesEnvoiMessagerieMessageries Le Dissez - Facture n° 17705 du 31 mars 2018 - STEPHANIE HALPERSON.pdf")
        '.addAttachment (PièceJointe)
        .Send
    End With
    Set Cdo_Message = Nothing

End Function

Quand j'utilise :

        .addAttachment ("W:BasesIrisFacturesEnvoiMessagerieMessageries Le Dissez - Facture n° 17705 du 31 mars 2018 - STEPHANIE HALPERSON.pdf")

ça marche très bien mais pas quand j'utilise la variable

Voilà comment je défini la valeur de la variable :

    PièceJointe = "W:BasesIrisFacturesEnvoiMessagerie" & DLookup("FeM_PDF_Nom", "T_Factures_Envoi_Messagerie", "FeM_Facture_Numéro =" & FirstFactNuméro)
    Me.Test = PièceJointe

Je vérifie dans mon formulaire par Me.Test que la valeur de la variable est la bonne

comment puis-je régler ce problème

Bon dimanche

Pierre

  
Réponse n° 7
--------
le 15/04/2018 13:51
par 3Stone
 
Administrateur

Bonjour,

Et si au lieu de ce barbare :

"W:BasesIrisFacturesEnvoiMessagerieMessageries Le Dissez - Facture n° 17705 du 31 mars 2018 - STEPHANIE HALPERSON.pdf"

tu essaies avec un nom plus conventionnel :

w:Document123456.pdf

cela fonctionne ?

Si oui, tu sais ce qu'il te reste à faire !

Note :

Un document doit être identifiable, mais pas être rédigé en bon français ou ressembler à une dissertation  wink

Donc, des "n°" et et autres espaces n'ont rien à y faire. Même le mot "facture" est superflu. Un code qui commence par "Fxxxxx" est largement  suffisant.

Cordialement,

Pierre (3Stone)

  
Réponse n° 8
--------
le 15/04/2018 16:15
par possible924
 
visiteur

Je pensais que l'informatique état au service des utilisateurs et non l'inverse !

    PièceJointe = "W:BasesIrisFacturesEnvoiMessagerie" & DLookup("FeM_PDF_Nom", "T_Factures_Envoi_Messagerie", "FeM_Facture_Numéro =" & FirstFactNuméro)
    Me.Test = PièceJointe

    .addAttachment (Me.Test)

Et là, ça marche ! Pour quelle raison Mystère et je préfèrerais me pas avoir recours à ce curieux artifice.

Je vais fignoler tout ça et peut être reprendre une partie du dernier code que tu as écrit our l'envoi avec Google. La partie de la gestion des erreurs.

Bonne soirée

Pierre

  
Réponse n° 9
--------
le 17/04/2018 20:19
par possible924
 
visiteur

Bonjour,

J'envoi mon lot de factures par mail, hélas, ce qui me gêne c(est le problème de variables dont je suis obligé de coller la valeur dans des champs du formulaire pour les récupérer ensuite en VBA.

Option Compare Database
Option Explicit

Public Destinataire As String
Public ObjetDuMessage As String
Public PièceJointe As String

'Si le serveur smtp par défaut n'est pas reconnu (clients mail non Microsoft), on pourra employer les fonctions ci-dessous.
Private Function GetSMTPServerConfig() As Object
    Dim Cdo_Config As New CDO.Configuration
    Dim Cdo_Fields As Object
    Set Cdo_Fields = Cdo_Config.Fields

    With Cdo_Fields
        .Item(cdoSendUsingMethod) = cdoSendUsingPort
        .Item(cdoSMTPServer) = DFirst("SMTP_Serveur", "T_Constantes")
        .Item(cdoSMTPServerPort) = DFirst("SMTP_Serveur_Port", "T_Constantes")
        .Update
    End With

    Set GetSMTPServerConfig = Cdo_Config
    Set Cdo_Config = Nothing
    Set Cdo_Fields = Nothing

End Function

'Syntaxe:
'Call SendMailCDO("Sender", "Destinataire", "Subject", "BodyText", "W:CheminMaFacture.pdf")
Private Function SendMailCDO(Sender As String, Destinataire, ObjetDuMessage, BodyText As String, PièceJointe)

    Dim Cdo_Message As New CDO.Message
    Set Cdo_Message.Configuration = GetSMTPServerConfig()

'Pour ces deux variables ci après pas de problème !    
Sender = DFirst("Email_Expéditeur", "T_Constantes")
BodyText = DFirst("Corps_Message", "T_Constantes")

    With Cdo_Message
        .From = Sender
        .To = Me.EmailDestinataire	'pour que ça fonctionne, le suis obligé de coller la valeur Destinataire de la variable dans un champ du formulaire 
        .Subject = Me.Objet		''pour que ça fonctionne, le suis obligé de coller la valeur ObjetDuMessage de la variable dans un champ du formulaire
        .TextBody = BodyText
        .addAttachment (Me.CheminEtPièce)	''pour que ça fonctionne, le suis obligé de coller la valeur de la variable PièceJointe dans un champ du formulaire
        .Send
    End With
    Set Cdo_Message = Nothing
End Function

Private Sub EnvoyerAvec_Click() 'par messagerie
'On utilise le Numéro de facture et non pas CléP_Facture
On Error GoTo Fin
If NbFactAvec >= 1 Then
    DoCmd.SetWarnings False
        'Purge de la table des factures à envoyer par messagerie
        DoCmd.RunSQL "Delete T_Factures_Envoi_Messagerie.CléP_Facture_Envoi_Messagerie FROM T_Factures_Envoi_Messagerie"
        'Peuplement de la table des factures à envoyer par messagerie "T_Factures_Envoi_Messagerie"
        DoCmd.OpenQuery "R_Factures_Envoi_Messagerie_PeuplementTable"
     
Dim NbFact_à_Envoyer As Integer
Dim FirstFactNuméro As Variant
'Dim Destinataire As String
'Dim PièceJointe As String
Dim qdf As DAO.QueryDef
    Set qdf = CurrentDb.QueryDefs!R_Factures_Etat

Do
    NbFact_à_Envoyer = DCount("FeM_Facture_Imprimé_PDF", "T_Factures_envoi_Messagerie", "FeM_Facture_Imprimé_PDF = 0")
    FirstFactNuméro = DMin("FeM_Facture_Numéro", "T_Factures_envoi_Messagerie", "FeM_Facture_Imprimé_PDF = 0")
        qdf.SQL = "SELECT R_Factures.*, R_Facture_Contenu.* FROM R_Factures LEFT JOIN R_Facture_Contenu " & _
        "ON R_Factures.CléP_Facture = R_Facture_Contenu.FC_Clé_Facture " & _
                    "WHERE R_Factures.Fact_Numéro = " & FirstFactNuméro
    Destinataire = DLookup("FeM_Messagerie_Destinataire", "T_Factures_Envoi_Messagerie", "FeM_Facture_Numéro = " & FirstFactNuméro)
    
    ObjetDuMessage = "Notre facture du " & DLookup("FeM_Facture_Date", "T_Factures_Envoi_Messagerie", "FeM_Facture_Numéro = " & FirstFactNuméro)
    Me.Objet = ObjetDuMessage
    Me.EmailDestinataire = Destinataire
    PièceJointe = "W:BasesIrisFacturesEnvoiMessagerie" & DLookup("FeM_PDF_Nom", "T_Factures_Envoi_Messagerie", "FeM_Facture_Numéro =" & FirstFactNuméro)
    Me.CheminEtPièce = PièceJointe
    DoCmd.RunSQL "UPDATE T_Factures_Envoi_Messagerie SET T_Factures_Envoi_Messagerie.FeM_Facture_Imprimé_PDF = -1 " & _
                    "WHERE T_Factures_Envoi_Messagerie.FeM_Facture_Numéro = " & FirstFactNuméro
                    
    'Crée le document PDF correspondant à la facture
    DoCmd.OutputTo acOutputReport, "E_Facture", "PDFFormat(*.pdf)", "W:BasesIrisFacturesEnvoiMessagerie" & DLookup("FeM_PDF_Nom", "T_Factures_Envoi_Messagerie", "FeM_Facture_Numéro =" & FirstFactNuméro), False, "", , acExportQualityScreen
    'Envoie l'Email avec la facture jointe
    Call SendMailCDO("Sender", "Destinataire", "Subject", "BodyText", "PièceJointe")

    'Met à joiur la date d'envoi de la facture
    DoCmd.RunSQL "UPDATE T_Factures SET T_Factures.Fact_Date_EnvoiMessagerie = " & Date * 1 & " WHERE T_Factures.Fact_Numéro = " & FirstFactNuméro
    Me.NbPDFEnvoyés = NbFactAvec - NbFact_à_Envoyer + 1

Loop Until NbFact_à_Envoyer = 1
     Me.Refresh
   'Vider le répertoire "W:BasesIrisFacturesEnvoiMessagerie"
    Kill "W:BasesIrisFacturesEnvoiMessagerie*.pdf"
Else
    If MsgBox("Il n'y a aucune facture sélectionnée !" & (Chr(10) & Chr(10)) & _
    "Vous devez sélectionner des factures" & Chr(10) & _
    "pour pouvoir les voir, les imprimer" & Chr(10) & _
    "ou bien les envoyer par messagerie." & Chr(10) & _
    "" & (Chr(10)), vbApplicationModal, CurrentDb.Properties("AppTitle")) = vbOK Then Exit Sub
End If
Fin:
    DoCmd.SetWarnings True
        'Remet la reqête de la facture d'origine
        qdf.SQL = "SELECT R_Factures.*, R_Facture_Contenu.* FROM R_Factures LEFT JOIN R_Facture_Contenu ON R_Factures.CléP_Facture = R_Facture_Contenu.FC_Clé_Facture"
        Set qdf = Nothing
End Sub

C'est cette partie qui me semble douteuse, je pense que je pourrais me passer de cet artifice :

Public Destinataire As String
Public ObjetDuMessage As String
Public PièceJointe As String


    ObjetDuMessage = "Notre facture du " & DLookup("FeM_Facture_Date", "T_Factures_Envoi_Messagerie", "FeM_Facture_Numéro = " & FirstFactNuméro)
    Me.Objet = ObjetDuMessage
    Me.EmailDestinataire = Destinataire
    PièceJointe = "W:BasesIrisFacturesEnvoiMessagerie" & DLookup("FeM_PDF_Nom", "T_Factures_Envoi_Messagerie", "FeM_Facture_Numéro =" & FirstFactNuméro)
    Me.CheminEtPièce = PièceJointe

    With Cdo_Message
        .From = Sender
        .To = Me.EmailDestinataire	'pour que ça fonctionne, le suis obligé de coller la valeur Destinataire de la variable dans un champ du formulaire 
        .Subject = Me.Objet		''pour que ça fonctionne, le suis obligé de coller la valeur ObjetDuMessage de la variable dans un champ du formulaire
        .TextBody = BodyText
        .addAttachment (Me.CheminEtPièce)	''pour que ça fonctionne, le suis obligé de coller la valeur de la variable PièceJointe dans un champ du formulaire
        .Send
    End With

Il doit bien y avoir une raison pour que ça ne marche pas directement avec la valeur des variables 

Peut être as tu une réponse

merci par avance

Pierre

  
Réponse n° 10
--------
le 18/04/2018 14:40
par 3Stone
 
Administrateur

Bonjour,

L'informatique est bien au service des utilisateurs, mais ce n'est pas pour que ceux-ci écrivent n'importe quoi en espérant que cela fonctionne tout de même !

C'est un programme bien écrit qui est au service de l'utilisateur tongue

Des choses comme :

& Chr(10) & _

ne sont  pas à employer. Il y a une constante pour cela : vbCRLF qu'il faut employer.

Ensuite, tu déclares une variable public :

Public Destinataire As String

Pourquoi ?

Ensuite tu utilises la variable "Destinataire" comme variant dans la fonction ?

Puis, des champs ? indépendants ?  

Me.Objet

Me.Destinataire

et tu veux que cela fonctionne ?

Le code mis à disposition fonctionne, a condition de ne pas modifier sans comprendre ce que l'on fait !!

Il faudrait aussi apprendre comment on transmet des valeurs à une fonction, cela aiderait sûrement...

Cordialement,

Pierre (3Stone)

  
sujet actif   sujet clos   Important!   Nouveau  
Rectifier message   Clôturer sujet   Remonter sujet