KutoolsforOffice — 一套方案,五大工具。事半功倍。三月特賣:20% 折扣

Outlook:如何在未收到回覆時自動重新寄送電子郵件

作者修改日期

當您傳送電子郵件給同事、合作夥伴或其他人,並急需對方回覆時,可啟用自動重新寄送功能;若在指定時間內未收到回覆,系統將自動再次寄送該郵件。

使用提醒與 VBA 設定「未收到回覆時自動重新寄送」


使用提醒與 VBA 設定「未收到回覆時自動重新寄送」

 

步驟 1:設定提醒,在指定時間進行通知

1. 針對您希望在未收到回覆時重新寄送的電子郵件(位於「已傳送郵件」資料夾中),請按一下滑鼠右鍵,並在彈出的快捷選單中選擇「後續追蹤」>「新增提醒」。

若無回應則重新傳送文件 1

2. 在彈出的「自訂」對話方塊中,請先勾選「提醒」核取方塊,接著於下方下拉式方塊中選擇您希望對方回覆的截止日期與時間,或直接在欄位中輸入日期與時間。設定完成後,點選「確定」。

若無回應則重新傳送文件 1
若無回應則重新傳送文件 1

步驟 2:插入 VBA 程式碼,於指定時間內未收到回覆時自動重新寄送郵件

3. 按下「Alt」+「F11」鍵,即可開啟「Microsoft Visual Basic for Applications」視窗。

4. 在「專案 – Project 1」窗格中雙擊「ThisOutlookSession」,建立空白指令碼,並將下方的 VBA 程式碼複製貼上至該空白指令碼中。

VBA:未收到回覆時重新寄送電子郵件

Public WithEvents GInboxItems As Outlook.Items
'UpdatebyExtendoffice20220413
Private Sub Application_Startup()
  Dim xInboxFld As Folder
  Set xInboxFld = Application.Session.GetDefaultFolder(olFolderInbox)
  Set GInboxItems = xInboxFld.Items
End Sub

'Judge
Private Sub GInboxItems_ItemAdd(ByVal Item As Object)
  Dim xSentItems As Outlook.Items
  Dim xMail As MailItem
  Dim i As Long
  Dim xSubject As String
  Dim xItemSubject As String
  Dim xSendTime As String
  On Error Resume Next
  Set xSentItems = Application.Session.GetDefaultFolder(olFolderSentMail).Items
  If Item.Class <> olMail Then Exit Sub
  For i = xSentItems.Count To 1 Step -1
    If xSentItems.Item(i).Class = olMail Then
      Set xMail = xSentItems.Item(i)
      xSubject = LCase(xMail.Subject)
      xSendTime = xMail.SentOn
      xItemSubject = LCase(Item.Subject)
      If (xItemSubject = "re: " & xSubject) Or (InStr(xItemSubject, xSubject) > 0) Then
        If Item.SentOn > xSendTime Then
           With xMail
             .ClearTaskFlag
             .ReminderSet = False
             .Save
           End With
        End If
      End If
    End If
  Next i
End Sub

'Reminder
Private Sub Application_Reminder(ByVal Item As Object)
  Dim xPrompt As String
  Dim xResponse As Integer
  Dim xFollowUpMail As Outlook.MailItem
  Dim xRcp As Recipient
  On Error Resume Next
  'Resend
  If (Item.Class <> olMail) Then Exit Sub
  xPrompt = "You haven't yet received the reply of " & Chr(34) & Item.Subject & Chr(34) & " within your expected time. Do you want to send a follow-up notification email?"
  xResponse = MsgBox(xPrompt, vbYesNo + vbQuestion, "Kutools for Outlook")
  If xResponse = vbNo Then Exit Sub
  Set xFollowUpMail = Application.CreateItem(olMailItem)
  With xFollowUpMail
    For Each xRcp In Item.Recipients
      .Recipients.Add (xRcp.Address)
    Next
    .Recipients.ResolveAll
    .Subject = "Follow Up: " & Chr(34) & Item.Subject & Chr(34)
    .Body = "Please respond to my email " & Chr(34) & Item.Subject & Chr(34) & " as soon as possible"
    .Attachments.Add Item
    .Display
  End With
End Sub

5. 儲存程式碼後,返回主介面,點選「檔案」>「選項」,在「Outlook 選項」視窗中,點選左側窗格的「信任中心」,再點選「信任中心設定」以開啟「信任中心」視窗;接著點選「巨集設定」,並確保右側已選取「啟用所有巨集(不建議;可能執行危險程式碼)」選項。設定完成後,依序點選「確定」>「確定」。

若無回應則重新傳送文件 1
若無回應則重新傳送文件 1

6. 現在,當設定提醒的已傳送郵件在指定時間到達時仍未收到回覆,系統會彈出對話方塊,詢問您是否要重新寄送郵件以發出通知。

若無回應則重新傳送文件 1

7. 點選「是」後,系統將彈出郵件視窗並附上先前的郵件內容,您可重新編輯內文,再點選「傳送」即可重新寄送郵件。

若無回應則重新傳送文件 1

8. 點選「否」,即可刪除該提醒。

若無回應則重新傳送文件 1

注意:若郵件在指定時間前已收到回覆,VBA 將自動取消該提醒。


最佳 Office 生產力工具

體驗全新 Kutools for Outlook,內含 100+ 項超強功能!立即點擊下載!

🤖KUTOOLS AI運用先進 AI 技術,輕鬆處理電子郵件——無論是回覆、摘要、優化、擴充、翻譯還是撰寫郵件,通通一鍵搞定!

📧 郵件自動化自動答覆(支援 POP 與 IMAP)預約寄送郵件寄信時依規則自動抄送密送自動轉發(高級規則)自動加入問候語自動將多收件人郵件拆分為個別訊息……

📨 郵件管理撤回郵件依主旨等條件封鎖詐騙郵件刪除重複郵件高級搜尋整合文件夾……

📁 附件專業版批次儲存批次解除附加批次壓縮自動保存自動拆離自動壓縮……

🌟 介面魔法😊更多精美酷炫表情符號重要郵件來到時提醒您最小化 Outlook 而非關閉……

👍 一鍵奇蹟帶附件全部答復防釣魚郵件🕘顯示發送者當前時間時區……

👩🏼‍🤝‍👩🏻 聯絡人與行事曆從選取的郵件中批次新增聯絡人將聯繫人組拆分為個別群組移除生日提醒……

用您的慣用語言暢享 Kutools — 完整支援英文、西班牙文、德文、法文、中文等 40 多種語言!

立即一鍵解鎖 Kutools for Outlook!別再等待,馬上下載,全面提升工作效率!

kutools for outlook 功能1kutools for outlook 功能2

🚀 一鍵下載 — 立即取得所有 Office 增益集

強烈推薦:Kutools for Office(5 合 1)

一鍵下載五個安裝程式,一次完成 — Kutools for Excel、Outlook、Word、PowerPointOffice Tab Pro立即點擊下載!

  • 一鍵便利:只需一次操作,即可下載全部五個安裝套件!
  • 🚀 隨時應對任何 Office 任務:按需安裝所需增益集,立即提升工作效率!
  • 🧰 包含:Kutools for Excel/Kutools for Outlook/Kutools for Word/Office Tab Pro/Kutools for PowerPoint