Note: The other languages of the website are Google-translated. Back to English
Accedi  \/ 
x
or
x
Registrati  \/ 
x

or

Come inviare più bozze contemporaneamente in Outlook?

Se sono presenti più bozze di messaggi nella cartella Bozze e ora, si desidera inviarli contemporaneamente senza inviarli uno per uno. Come hai potuto affrontare questo lavoro in modo rapido e semplice in Outlook?

Invia tutte le bozze di messaggi contemporaneamente in Outlook con il codice VBA


Invia tutte le bozze di messaggi contemporaneamente in Outlook con il codice VBA

I seguenti codici VBA possono aiutarti a inviare tutte le email bozze o selezionate dalla cartella Bozze contemporaneamente, per favore fai come segue:

1. Tieni premuto il ALT + F11 chiavi per aprire il Microsoft Visual Basic, Applications Edition finestra.

2. Quindi fare clic inserire > Modulo, copia e incolla sotto il codice nel modulo vuoto aperto, vedi screenshot:

Codice VBA: invia tutte le bozze di e-mail contemporaneamente in Outlook:

Sub SendAllDraftEmails()
Dim xAccount As Account
Dim xDraftFld As Folder
Dim xItemCount As Integer
Dim xCount As Integer
Dim xDraftsItems As Outlook.Items
Dim xPromptStr As String
Dim xYesOrNo As Integer
Dim i As Long
Dim xCurFld As Folder
Dim xTmpFld As Folder
On Error Resume Next
xItemCount = 0
xCount = 0
Set xTmpFld = Nothing
Set xCurFld = Application.ActiveExplorer.CurrentFolder
For Each xAccount In Outlook.Application.Session.Accounts
    Set xDraftFld = xAccount.DeliveryStore.GetDefaultFolder(olFolderDrafts)
    xItemCount = xItemCount + xDraftFld.Items.Count
    If xDraftFld.EntryID = xCurFld.EntryID Then
        Set xTmpFld = xCurFld.Parent
    End If
Next xAccount
Set xDraftFld = Nothing
If xItemCount > 0 Then
   xPromptStr = "Are you sure to send out all the drafts?"
    xYesOrNo = MsgBox(xPromptStr, vbQuestion + vbYesNo, "Kutools for Outlook")
    If xYesOrNo = vbYes Then
        If Not xTmpFld Is Nothing Then
            Set Application.ActiveExplorer.CurrentFolder = xTmpFld
        End If
        VBA.DoEvents
        For Each xAccount In Outlook.Application.Session.Accounts
            Set xDraftFld = xAccount.DeliveryStore.GetDefaultFolder(olFolderDrafts)
            Set xDraftsItems = xDraftFld.Items
            For i = xDraftsItems.Count To 1 Step -1
                If xDraftsItems.Item(i).Recipients.Count <> 0 Then
                    xDraftsItems.Item(i).sEnd
                    xCount = xCount + 1
                End If
            Next
        Next xAccount
        VBA.DoEvents
        Set Application.ActiveExplorer.CurrentFolder = xCurFld
        MsgBox "Successfully sent " & xCount & " messages", vbInformation, "Kutools for Outlook"
    End If
Else
    MsgBox "No Drafts!", vbInformation + vbOKOnly, "Kutools for Outlook"
End If
End Sub

3. Quindi salvare il codice e premere F5 tasto per eseguire questo codice, verrà visualizzata una finestra di messaggio per ricordarti se inviare tutte le bozze, fare clic su, vedi screenshot:

4. E verrà visualizzata una finestra di dialogo per ricordarti quante bozze di email sono state inviate, vedi screenshot:

5. E poi clicca OK pulsante, tutte le email nel file Abbozzo la cartella verrà inviata contemporaneamente, vedi screenshot:

Note:

1. Il codice sopra invierà tutte le bozze di email da tutti gli account in Outlook.

2. Se desideri inviare solo email specifiche dalla cartella Bozze, applica il seguente codice VBA:

Codice VBA: invia email selezionate dalla cartella Bozze:

Sub SendSelectedDraftEmails()
Dim xSelection As Selection
Dim xPromptStr As String
Dim xYesOrNo As Integer
Dim i As Long
Dim xAccount As Account
Dim xCurFld As Folder
Dim xDraftsFld As Folder
Dim xTmpFld As Folder
Dim xArr() As String
Dim xCount As Integer
Dim xMail As MailItem
On Error Resume Next
xCount = 0
Set xTmpFld = Nothing
Set xCurFld = Application.ActiveExplorer.CurrentFolder
For Each xAccount In Outlook.Application.Session.Accounts
    Set xDraftsFld = xAccount.DeliveryStore.GetDefaultFolder(olFolderDrafts)
    If xDraftsFld.EntryID = xCurFld.EntryID Then
        Set xTmpFld = xCurFld.Parent
    End If
Next xAccount
If xTmpFld Is Nothing Then
    MsgBox "The current folder is not a draft folder", vbInformation, "Kutools for Outlook"
    Exit Sub
End If
Set xSelection = Outlook.Application.ActiveExplorer.Selection
If xSelection.Count > 0 Then
    xPromptStr = "Are you sure to send out the selected " & xSelection.Count & " draft item(s)?"
    xYesOrNo = MsgBox(xPromptStr, vbQuestion + vbYesNo, "Kutools for Outlook")
    If xYesOrNo = vbYes Then
        ReDim xArr(xSelection.Count - 1)
        For i = 1 To xSelection.Count
            xArr(i - 1) = xSelection.Item(i).EntryID
        Next
        Set Application.ActiveExplorer.CurrentFolder = xTmpFld
        VBA.DoEvents
        For i = 0 To UBound(xArr)
            Set xMail = Application.Session.GetItemFromID(xArr(i))
            If xMail.Recipients.Count <> 0 Then
                xMail.sEnd
                xCount = xCount + 1
            End If
        Next
        VBA.DoEvents
        Set Application.ActiveExplorer.CurrentFolder = xCurFld
        MsgBox "Successfully sent " & xCount & " messages", vbInformation, "Kutools for Outlook"
    End If
Else
    MsgBox "No items selected!", vbInformation, "Kutools for Outlook"
End If
End Sub

Articoli Correlati:

Come inviare un'e-mail a più destinatari individualmente in Outlook?

Come inviare e-mail di massa personalizzate a un elenco da Excel tramite Outlook?

Come inviare un calendario a più destinatari individualmente in Outlook?

Come inviare e-mail a più destinatari senza che loro lo sappiano in Outlook?


Kutools for Outlook: porta 100 funzionalità avanzate in Outlook e semplifica notevolmente il lavoro!

  • Auto CC / BCC dalle regole durante l'invio di e-mail; Avanzamento automatico Email multiple personalizzate; Risposta automatica senza server di scambio e più funzioni automatiche ...
  • Avviso BCC - mostra il messaggio quando provi a rispondere a tutti se il tuo indirizzo e-mail è nell'elenco BCC; Ricorda quando mancano allegatie altre funzioni di promemoria ...
  • Rispondi (tutti) con tutti gli allegati nella conversazione di posta; Rispondi a molte email in secondi; Aggiunta automatica di saluto quando rispondi; Aggiungi la data all'oggetto ...
  • Strumenti per gli allegati: gestisci tutti gli allegati in tutti i messaggi, Scollegamento automatico, Comprimi tutto, Rinomina tutto, Salva tutto ... Rapporto rapido, Conta le email selezionate...
  • E-mail spazzatura potenti per abitudine; Rimuovi messaggi e contatti duplicati... Consentono di fare in modo più intelligente, veloce e migliore in Outlook.
girato kutools outlook scheda kutools 1180x121
girato kutools outlook kutools plus tab 1180x121
 
Say something here...
symbols left.
You are guest
or post as a guest, but your post won't be published automatically.
Loading comment... The comment will be refreshed after 00:00.
  • To post as a guest, your comment is unpublished.
    JamesWood · 8 months ago
    Hi guys. Thought I'd share. Here's my code for sending all drafts:

    Sub SendAllDrafts() 'By jamesmalcolmwood@gmail.com

    If MsgBox("Are you sure you want to send ALL the items in your drafts folder?", _
    vbQuestion + vbYesNo) <> vbYes Then Exit Sub

    Dim myNamespace As Outlook.NameSpace 'Change view to Inbox to avoid inline error
    Set myNamespace = Application.GetNamespace("MAPI") 'Change view to Inbox to avoid inline error
    Set Application.ActiveExplorer.CurrentFolder = _
    myNamespace.GetDefaultFolder(olFolderInbox) 'Change view to Inbox to avoid inline error

    Dim fldDraft As MAPIFolder, msg As Outlook.MailItem, intCount As Integer
    Set fldDraft = Outlook.GetNamespace("MAPI").GetDefaultFolder(olFolderDrafts) 'Sends all drafts in your main drafts folder. For a subfolder, add .Folders("folder name")
    intCount = 0
    Do While fldDraft.Items.count > 0
    Set msg = fldDraft.Items(1)
    msg.Send
    intCount = intCount + 1
    Loop
    If Not (msg Is Nothing) Then Set msg = Nothing
    Set fldDraft = Nothing
    MsgBox intCount & " messages sent", vbInformation + vbOKOnly

    End Sub
  • To post as a guest, your comment is unpublished.
    James · 8 months ago
    This code sends all drafts in a subfolder called Merge Tools (it asks you before sending). I'm sure you guys can edit it to suit your needs though. It's far simpler. Enjoy :)

    Sub SendAllMergeToolsDrafts()

    If MsgBox("Are you sure you want to send ALL the items in your Merge Tools drafts folder?", _
    vbQuestion + vbYesNo) <> vbYes Then Exit Sub

    Dim myNamespace As Outlook.NameSpace 'Change view to Inbox to avoid inline error
    Set myNamespace = Application.GetNamespace("MAPI") 'Change view to Inbox to avoid inline error
    Set Application.ActiveExplorer.CurrentFolder = _
    myNamespace.GetDefaultFolder(olFolderInbox) 'Change view to Inbox to avoid inline error

    Dim fldDraft As MAPIFolder, msg As Outlook.MailItem, intCount As Integer
    Set fldDraft = Outlook.GetNamespace("MAPI").GetDefaultFolder(olFolderDrafts).Folders("Merge Tools") 'Sends all drafts in the Merge Tools folder only
    intCount = 0
    Do While fldDraft.Items.count > 0
    Set msg = fldDraft.Items(1)
    msg.Send
    intCount = intCount + 1
    Loop
    If Not (msg Is Nothing) Then Set msg = Nothing
    Set fldDraft = Nothing
    MsgBox intCount & " messages sent", vbInformation + vbOKOnly

    End Sub
  • To post as a guest, your comment is unpublished.
    Julian · 1 years ago
    Hi, quick question maybe you have an Idea. We have an external application that saves all mails to the drafts folder. if i run the macro we have the problem, that only the first mail in the list is beeing sent correctly, all other mails are deferred because it adds quote marks ' ' to the mail adress.
    Is there a way to avoid this?
  • To post as a guest, your comment is unpublished.
    Lukas · 2 years ago
    Can you explain why the last mail (i = 1) is recreated in a new MailItem instead of just .Send?

    Thanks.
  • To post as a guest, your comment is unpublished.
    denbo · 2 years ago
    We used the script to send all draft emails at once for a batch of statement emails generated from sage 200. The emails in the sent items look fine but customers are are receiving them with the body text in Chinese! Any ideas what could be happening here?
  • To post as a guest, your comment is unpublished.
    Bill · 2 years ago
    Anybody get some emails sent to the deleted folder doing this?
    • To post as a guest, your comment is unpublished.
      Frank · 2 years ago
      Same problem: if you select 4 messages, after sending three of them ar in trash folder (because of the "xDraftsItems.Item(i).Delete" statement)
    • To post as a guest, your comment is unpublished.
      skyyang · 2 years ago
      Hi, Bill,
      Do you want to send multiple selected emails from deleted foder?
      Please give your problem more detailed, thank you!
      • To post as a guest, your comment is unpublished.
        Darewin · 8 months ago
        Hi skyyang, Im facing the same problem. I draft usually 15-20 emails and then use this code to send them all at once, but later realise that one of those emails do not get sent, rather they are sent to my 'Deleted' folder. Even the prompt says the correct number of emails for eg: '20 emails sent' but when I check, only 19 would have been sent, one I will find it lying in my deleted items folder. I want all the emails to be sent to their recipients without error. Can you please tell me why this happens. Please help.
        • To post as a guest, your comment is unpublished.
          skyyang · 8 months ago
          Hi, Darewin,
          We have updated the above codes, please try again, thank you!
  • To post as a guest, your comment is unpublished.
    Donnie · 2 years ago
    I have multiple exchange accounts. I want to have one of the accounts that isn't my default to be the sender. Where would I insert this in the code? Thanks!
  • To post as a guest, your comment is unpublished.
    Cathleen · 2 years ago
    Copied as per above but when I press F5 nothing happens
    • To post as a guest, your comment is unpublished.
      skyyang · 2 years ago
      Hi, Cathleen,
      The above code works fine in my Outlook, which Outlook version do you use?
  • To post as a guest, your comment is unpublished.
    Colin · 3 years ago
    Brilliant, worked a charm, thank you :)
    • To post as a guest, your comment is unpublished.
      Günther Haas · 5 months ago
      einfach nur perfekt. Herzlichen Dank