IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

VBA Outlook Discussion :

Changer de sujet automatiquement


Sujet :

VBA Outlook

  1. #21
    Nouveau membre du Club
    Inscrit en
    Août 2011
    Messages
    58
    Détails du profil
    Informations forums :
    Inscription : Août 2011
    Messages : 58
    Points : 28
    Points
    28
    Par défaut
    exemple :

    lerjzlekrz
    zerzerzer
    zerzerzerzerzerzerzer
    sdfsd
    fdsfsdfsdfsdfsdfsdf
    0293019109203920

    boite de dialogue vide pour afficher la dernière ligne, et qui affiche 6 pour le nombre de ligne...

  2. #22
    Expert éminent sénior


    Profil pro
    Inscrit en
    Juin 2003
    Messages
    14 008
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 14 008
    Points : 20 038
    Points
    20 038
    Par défaut
    si le retour est 6 , tu as bien une ligne vide à la fin ...

    voici pour "sauter" les lignes vides en fin de message :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
     Sub GestionMailsKeybon(Item As Outlook.MailItem)
       Dim tb
       Dim i As Integer
       Dim stDer As String 'Derniere ligne
       tb = Split(Item.Body, vbCrLf) '
       i = UBound(tb)
       stDer = tb(i)
       While stDer = "" And i >= 0
        i = i - 1
        stDer = tb(i)
       Wend
       If Len(stDer) > 8 And IsNumeric(stDer) Then 'Si longueur dernière ligne supérieure à 8et valeur numérique
        Item.Subject = Item.Subject & " [" & stDer & "]"
        Item.Save
       End If
    End Sub

  3. #23
    Nouveau membre du Club
    Inscrit en
    Août 2011
    Messages
    58
    Détails du profil
    Informations forums :
    Inscription : Août 2011
    Messages : 58
    Points : 28
    Points
    28
    Par défaut
    Merci beaucoup !!! Cela fonctionne, à part pour les numéros de téléphone avec des espaces, ex : +32 476 9598

    Aussi, j'aimerai comme je vous l'avais dit que le Receive/Send soit tenu en compte :

    ex d'e-mail 1 :

    Please open the attached document. It contains a copy of a Transmitted/Received Fax. For more information on DELL products and solutions, please visit http://www.dell.com.
    Fax Job : Send
    0031736821171

    ex d'e-mail 2 :

    Please open the attached document. It contains a copy of a Transmitted/Received Fax. For more information on DELL products and solutions, please visit http://www.dell.com.
    Fax Job : Receive
    0032 64 520639


    Pourriez-vous m'aider à récupérer le mot Receive ou Send (sur l'avant-dernière ligne, après 'Fax Job : ') et l'ajouter au sujet ?

    Merci encore, vous m'êtes d'une immense aide!!

  4. #24
    Expert éminent sénior


    Profil pro
    Inscrit en
    Juin 2003
    Messages
    14 008
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 14 008
    Points : 20 038
    Points
    20 038
    Par défaut
    Je pense que tu devrais y arriver seul avec un peu de réflexion ...
    Citation Envoyé par keybon Voir le message
    Merci beaucoup !!! Cela fonctionne, à part pour les numéros de téléphone avec des espaces, ex : +32 476 9598
    ..
    Citation Envoyé par bbil
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
      If Len(stDer) > 8 And IsNumeric(stDer) Then 'Si longueur dernière ligne supérieure à 8 et valeur numérique

    Citation Envoyé par keybon Voir le message
    ...
    Pourriez-vous m'aider à récupérer le mot Receive ou Send (sur l'avant-dernière ligne, après 'Fax Job : ') et l'ajouter au sujet ?
    ...
    ben si tb(i) est la dernière ligne ... tb(i-1) => ..
    voir ensuite InStr..

  5. #25
    Nouveau membre du Club
    Inscrit en
    Août 2011
    Messages
    58
    Détails du profil
    Informations forums :
    Inscription : Août 2011
    Messages : 58
    Points : 28
    Points
    28
    Par défaut
    oui je sais, j'ai changé le code en écrivant > 2 et en insérant MsgBox stDer et stAvantDer... et en fait les messages box ne s'affichent meme pas... donc jez pense qu'il ne considère plus que stDer est numérique :


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
      If Len(stDer) > 2 And IsNumeric(stDer) Then
        MsgBox stDer
        MsgBox stAvantDer
        Item.Subject = Item.Subject & " [" & stDer & "]"
        Item.Save
       End If

  6. #26
    Nouveau membre du Club
    Inscrit en
    Août 2011
    Messages
    58
    Détails du profil
    Informations forums :
    Inscription : Août 2011
    Messages : 58
    Points : 28
    Points
    28
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    Sub GestionMailsKeybon(Item As Outlook.MailItem)
       Dim tb
       Dim i As Integer
       Dim stDer As String 'Derniere ligne
       Dim stAvantDer As String
       tb = Split(Item.Body, vbCrLf) '
       i = UBound(tb)
       stDer = tb(i)
       stAvantDer = tb(i - 1)
       While stDer = "" And i >= 0
        i = i - 1
        stDer = tb(i)
       Wend
       If Len(stDer) > 2 And IsNumeric(stDer) Then 'Si longueur dernière ligne supérieure à 8et valeur numérique
        MsgBox stDer
        MsgBox stAvantDer
        Item.Subject = Item.Subject & " [" & stDer & "]"
        Item.Save
       End If
    End Sub
    donc voilà ce que j'ai changé dans le code... je n'ai pas compris ce que vous vouliez dire par InStr ?

  7. #27
    Expert éminent sénior


    Profil pro
    Inscrit en
    Juin 2003
    Messages
    14 008
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 14 008
    Points : 20 038
    Points
    20 038
    Par défaut
    pour le +33 ... ajoute après le dernier wend un stop :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    Wend
    stop 
    If Len(stDer) > 2 And IsNumeric(stDer) Then
    et visualise en passant la souris dessus la valeur réelle de stDer de IsNumeric(stDer) ...

    Pour l'avant dernière ligne ...tu n'as pas placé stAvantDer = tb(i - 1) au bon endroit place le après la boucle While ... wend destiné à laisser passer les lignes vide..

    pour InStr as tu actionné la touche sur InStr ? cette instruction va te permettre de teste si Send ou Receive est présent dans stDerLigne...

  8. #28
    Nouveau membre du Club
    Inscrit en
    Août 2011
    Messages
    58
    Détails du profil
    Informations forums :
    Inscription : Août 2011
    Messages : 58
    Points : 28
    Points
    28
    Par défaut
    Comment je dois faire pour activer la touche f1 sur InStr? Je ne comprends pas bien ...

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    Sub GestionMailsKeybon(Item As Outlook.MailItem)
       Dim tb
       Dim i As Integer
       Dim stDer As String 'Derniere ligne
       Dim stAvantDer As String
       tb = Split(Item.Body, vbCrLf) '
       i = UBound(tb)
       stDer = tb(i)
       While stDer = "" And i >= 0
        i = i - 1
        stDer = tb(i)
       Wend
       Stop
       stAvantDer = tb(i - 1)
       If Len(stDer) > 2 And IsNumeric(stDer) Then 'Si longueur dernière ligne supérieure à 8et valeur numérique
        MsgBox stDer
        MsgBox stAvantDer
        Item.Subject = Item.Subject & " [" & stDer & "]"
        Item.Save
       End If
    End Sub
    C'est bon comme ca?

  9. #29
    Expert éminent sénior


    Profil pro
    Inscrit en
    Juin 2003
    Messages
    14 008
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 14 008
    Points : 20 038
    Points
    20 038
    Par défaut
    Citation Envoyé par bbil Voir le message
    et visualise en passant la souris dessus la valeur réelle de stDer de IsNumeric(stDer) ......

  10. #30
    Nouveau membre du Club
    Inscrit en
    Août 2011
    Messages
    58
    Détails du profil
    Informations forums :
    Inscription : Août 2011
    Messages : 58
    Points : 28
    Points
    28
    Par défaut
    Je suis vraiment desolé mais je ne comprends pas... je dois écrire InStr quelque part? à quel moment je dois appuyer sur F1 ? ...

  11. #31
    Expert éminent sénior


    Profil pro
    Inscrit en
    Juin 2003
    Messages
    14 008
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 14 008
    Points : 20 038
    Points
    20 038
    Par défaut
    Citation Envoyé par keybon Voir le message
    Je suis vraiment desolé mais je ne comprends pas... je dois écrire InStr quelque part? à quel moment je dois appuyer sur F1 ? ...
    ne sais-tu pas te servir de l'aide en ligne intégré au VBA Outlook ? tu tape le code InStr puis F1 ...

    sinon voir :
    I-E. Renvoyer la position de la première occurrence d'une chaîne dans une autre chaîne

    ainsi avec InStr tu peu tester la présence de Send ou Receive (si Instr..>0)..



    tu ne m'as pas répondu pour le cas "+33 ...." que voit tu ;

    Envoyé par bbil
    et visualise en passant la souris dessus la valeur réelle de stDer de IsNumeric(stDer) ......

  12. #32
    Nouveau membre du Club
    Inscrit en
    Août 2011
    Messages
    58
    Détails du profil
    Informations forums :
    Inscription : Août 2011
    Messages : 58
    Points : 28
    Points
    28
    Par défaut
    stDer = +32 485 778866
    et stAvantDer = ""
    Il ne reconnait donc pas ce que contient l'avant-dernière ligne...

    voilà le code que j'ai écris, en sachant qu'il y a surement bcp de fautes, pourriez-vous le corriger?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    Sub GestionMailsKeybon(Item As Outlook.MailItem)
       Dim tb
       Dim i As Integer
       Dim stDer As String 'Derniere ligne
       Dim stAvantDer As String
       Dim compare As Integer
       tb = Split(Item.Body, vbCrLf) '
       i = UBound(tb)
       stDer = tb(i)
       While stDer = "" And i >= 0
        i = i - 1
        stDer = tb(i)
       Wend
       Stop
       stAvantDer = tb(i - 1)
       compare = InStr(1, stAvantDer, Receive)
       If compare = 0 Then
       Item.Subject = Received
       End If
     
       compare = InStr(1, stAvantDer, Send)
       If compare = 0 Then
       Item.Subject = Send
       End If
     
       If Len(stDer) > 2 And IsNumeric(stDer) Then 'Si longueur dernière ligne supérieure à 8et valeur numérique
        Item.Subject = Item.Subject & " [" & stDer & "]"
        Item.Save
       End If
    End Sub

  13. #33
    Expert éminent sénior


    Profil pro
    Inscrit en
    Juin 2003
    Messages
    14 008
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 14 008
    Points : 20 038
    Points
    20 038
    Par défaut
    pour Voir le stAvantDer le stop est mal placé , il faut le placer après l'affectation de stAvantDer..

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
      Wend
     
       stAvantDer = tb(i - 1)
       Debug.print "stDer : " & stDer & " : " & IsNumeric(stDer)
       Debug.print stAvantDer
       Stop 'Voir résultat fenêtre exécution

    Pour le test de InStr Il me semble que tu fait cela à l’envers si INstr( ..) = 0 cela veut dire que la chaine testée n'est pas présente ..

    avec ce code tu affecte au sujet le contenu de la variable Received ..:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Item.Subject = Received
    c'est ce que tu veux faire ?? s'il s'agit du texte Receveid il faut le place entre guillemet (sachant que tu efface totalement le précédent sujet)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Item.Subject = "Received "

  14. #34
    Nouveau membre du Club
    Inscrit en
    Août 2011
    Messages
    58
    Détails du profil
    Informations forums :
    Inscription : Août 2011
    Messages : 58
    Points : 28
    Points
    28
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    Sub GestionMailsKeybon(Item As Outlook.MailItem)
       Dim tb
       Dim i As Integer
       Dim stDer As String 'Derniere ligne
       Dim stAvantDer As String
       Dim compare As Integer
       tb = Split(Item.Body, vbCrLf) '
       i = UBound(tb)
       stDer = tb(i)
       While stDer = "" And i >= 0
        i = i - 1
        stDer = tb(i)
       Wend
       stAvantDer = tb(i - 1)
       Debug.Print "stDer : " & stDer & " : " & IsNumeric(stDer)
       Debug.Print stAvantDer
       Stop
       compare = InStr(1, stAvantDer, Receive)
       If compare = 0 Then
       Item.Subject = "Sent"
       End If
     
       compare = InStr(1, stAvantDer, Receive)
       If compare <> 0 Then
       Item.Subject = "Received"
       End If
     
       If Len(stDer) > 2 And IsNumeric(stDer) Then 'Si longueur dernière ligne supérieure à 8et valeur numérique
        Item.Subject = Item.Subject & " [" & stDer & "]"
        Item.Save
       End If
    End Sub
    Comme cela?

  15. #35
    Expert éminent sénior


    Profil pro
    Inscrit en
    Juin 2003
    Messages
    14 008
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 14 008
    Points : 20 038
    Points
    20 038
    Par défaut
    Pour le test receive/Send ( c'est bien Send et pas Sent ?)

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    (...)
      If InStr(1, stAVantDer, "Receive") <> 0 Then
       Item.Subject = "Received" 'Remplace le sujet courant par Received
       End If
    (...)

Discussions similaires

  1. Macro pour remplir un sujet automatiquement
    Par jouvrard dans le forum VBA Outlook
    Réponses: 7
    Dernier message: 20/09/2017, 11h12
  2. Changer du texte automatiquement
    Par franquis dans le forum Général JavaScript
    Réponses: 0
    Dernier message: 26/11/2009, 16h35
  3. changer la langue automatiquement avec javascript
    Par Amel_B dans le forum Général JavaScript
    Réponses: 3
    Dernier message: 04/03/2009, 09h48
  4. Changer la langue automatique à la réception focus
    Par saidm dans le forum VB 6 et antérieur
    Réponses: 26
    Dernier message: 02/12/2007, 21h14
  5. changer titre graphique automatiquement
    Par stephsen dans le forum Access
    Réponses: 1
    Dernier message: 01/11/2005, 15h16

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo