使用Excel快速发送大量的电子邮件

使用Excel快速发送大量的电子邮件。两个步骤:

1. 准备发送数据:

a.) 打开Excel,新Book1.xlsx

b.) 填写以下内容。

第一列:接受者,第二列:邮件标题,第三列:文,第四列:附件路径

注意:附件路径中可以有中文,但是不能有空格

这里你可以写更多内容,每一行作为一封邮件发出。

注意:邮件正文是黑白文本内容。不支持加粗、字体颜色等。(如果你需要支持彩色的邮件。后面将会给出解决办法)

2. 编写宏发送邮件

a.) Alt + F11 打开宏编辑器,菜单中选:插入->模块

b.) 将下面的代码粘贴到模块代码编辑器中:

‘代码list-1

Public Declare Function SetTimer Lib "user32" _
        (ByVal hwnd As Long, ByVal nIDEvent As Long, ByVal uElapse As Long, ByVal lpTimerfunc As Long) As Long
Public Declare Function KillTimer Lib "user32" _
        (ByVal hwnd As Long, ByVal nIDEvent As Long) As Long
Private Declare Sub Sleep Lib "kernel32" (ByVal dwMilliseconds As Long)

Function WinProcA(ByVal hwnd As Long, ByVal uMsg As Long, ByVal idEvent As Long, ByVal SysTime As Long) As Long
    KillTimer 0, idEvent
    DoEvents
    Sleep 100
    ‘使用Alt+S发送邮件,这是本文的关键之处。免安全提示自动发送邮件全靠它了
    Application.SendKeys "%s"
End Function

‘ 发送单个邮件的子程序
Sub SendMail(ByVal to_who As String, ByVal subject As String, ByVal body As String, ByVal attachement As String)
    Dim objOL As Object
    Dim itmNewMail As Object
    ‘引用Microsoft Outlook 对象
    Set objOL = CreateObject("Outlook.Application")
    Set itmNewMail = objOL.CreateItem(olMailItem)
    With itmNewMail
        .subject = subject  ‘主旨
        .body = body   ‘正文本文
        .To = to_who  ‘收件者
        .Attachments.Add attachement ‘附件,如果你不需要发送附件。可以把这一句删掉即可,Excel中的第四列留空,不能删哦
        .Display  ‘启动Outlook发送窗口
        SetTimer 0, 0, 0, AddressOf WinProcA
    End With
    Set objOL = Nothing
    Set itmNewMail = Nothing
End Sub

‘批量发送邮件
Sub BatchSendMail()
    Dim rowCount, endRowNo
    endRowNo = Cells(1, 1).CurrentRegion.Rows.Count
    ‘逐行发送邮件
    For rowCount = 1 To endRowNo
        SendMail Cells(rowCount, 1), Cells(rowCount, 2), Cells(rowCount, 3), Cells(rowCount, 4)
    Next
End Sub

最终代码编辑器中的效果如下图:

i

为了正确执行代码,你还需要在

菜单中选择: 工具->引用 中的Microseft Outlook X.0 Object Library  勾选上 (X.0是版本号。不同机器可能不一样)

c.) 粘贴好代码、勾选上上面的东东后可以发送邮件了,点击上图A红圈所示的绿色三角按钮,会弹出下图所示的对话框。点运行,就开始批量发送邮件了。

d.) 如果你想确认你的邮件是否都发出去了,可以去Outlook的“已发送邮件”文件夹中查看,是否有你希望发出的邮件。如果有,恭喜你,收工~~

---------------------------------------------------------------------

下面讲解

1. 如何发送彩色的邮件

2. 如何替换正文中的部分内容,例如,每一封邮件中可能最开始的称呼不同,给对方报出的数字不同等

3. 如何发送多附件

---------------------------------------------------------------------

1. 如何发送彩色邮件

发送彩色邮件需要两步,

第一步:上面的代码需要改一句(红色加粗文本,body改成HTMLBody):

‘代码list-2

‘ 发送单个邮件的子程序
Sub SendMail(ByVal to_who As String, ByVal subject As String, ByVal body As String, ByVal attachement As String)
    Dim objOL As Object
    Dim itmNewMail As Object
    ‘引用Microsoft Outlook 对象
    Set objOL = CreateObject("Outlook.Application")
    Set itmNewMail = objOL.CreateItem(olMailItem)
    With itmNewMail
        .subject = subject  ‘主旨
        ‘~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
         .HTMLbody = body   ‘正文本文,仅仅这一行跟前面不同,其余都是一样的哦~
               ‘~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
        .To = to_who  ‘收件者
        .Attachments.Add attachement ‘附件
        .Display  ‘启动Outlook发送窗口
        SetTimer 0, 0, 0, AddressOf WinProcA 
  End With    Set objOL = Nothing
    Set itmNewMail = NothingEnd Sub

第二步:修改excel第三列(C列)的内容。这需要你懂一点点HTML语言

例如,希望在邮件中将“报税单”三个字变红,加粗,则将第三列的内容修改为:

您好,下面是这一周的<font color="red"><b>报税单</b></font>,…

最终效果如图:

去发件箱里看看效果吧:

注意:在Excel里面编辑正文,进行加粗、加颜色的操作不会生效哦。必须用HTML自己来。sorry哦 不会HTML的朋友可以新浪微博follow我帮忙:@研究员Raywill

2. 如何替换正文部分内容

分两步:

1. 换Excel内容

2. 换代码

1. 换Excel内容:

将变化的部分用[==xxxx==]这样的形式替换掉。

注意:中间没有空格。

例如上图,数字[==1==]会被E列的内容替换掉。[==2==]会被F列的内容替换掉,依此类推,如果有更多。就添加更多列。[==3==], [==4==]等等。

2. 换代码,将 "批量发送邮件"这一段程序完全替换成下面的代码:

‘批量发送邮件
Sub BatchSendMail()
    Dim rowCount, endRowNo
    Dim newBody
    Dim replaceCount, maxReplaceCount
    Dim pattern
    endRowNo = Cells(1, 1).CurrentRegion.Rows.Count

    ‘逐行发送邮件
    For rowCount = 1 To endRowNo
        ‘ 替换当前行模板内容
        maxReplaceCount = 2   ‘ 有几处替换就写几。例子中有两处。就写2
        newBody = Cells(rowCount, 3)

        For replaceCount = 1 To maxReplaceCount
            pattern = "[==" & CStr(replaceCount) & "==]"
            newBody = WorksheetFunction.Substitute(newBody, pattern, Cells(rowCount, 4 + replaceCount))
        Next
        ‘ 替换好了。发邮件咯!
        SendMail Cells(rowCount, 1), Cells(rowCount, 2), newBody, Cells(rowCount, 4)

    Next
End Sub

注意:上面“maxReplaceCount = 2"这一行代码,2需要改成你自己的值,替换几个地方就写几(新添加了几个列就写几)上面添加了E、F两列,就是2,如果你添加了3处替换(E、F、G列),就写3.

不过,对于需要重复替换的内容,不需要添加新列,例如。《大话西游》在邮件中出现了两次,可以重复使用[==2==]来代表。

3. 如何发送多附件

在实际应用场景中可能需要发送多封附件。其实很简单,将SendMail子程序修改成下面的样子即可:

‘ 发送单个邮件的子程序
Sub SendMail(ByVal to_who As String, ByVal subject As String, ByVal body As String, ByVal attachement As String)
    Dim objOL As Object
    Dim itmNewMail As Object
    Dim attaches
    Dim attach

    ‘引用Microsoft Outlook 对象
    Set objOL = CreateObject("Outlook.Application")
    Set itmNewMail = objOL.CreateItem(olMailItem)
    With itmNewMail
        .subject = subject  ‘主旨
        .HTMLbody = body   ‘正文本文
        .To = to_who  ‘收件者
        .Display  ‘启动Outlook发送窗口
        attaches = Split(attachement, ";")

        For Each attach In attaches
            If (Len(attach) > 0) Then
                .Attachments.Add attach
            End If
        Next
        SetTimer 0, 0, 0, AddressOf WinProcA
    End With

    Set objOL = Nothing
    Set itmNewMail = Nothing
End Sub

在Excel的附件列(第三列),多个附件用半角的分号分隔开(是”;"。不是”。“)。例如:

c:\doc\毕业证书附件.jpg;c:\doc\校方证明书.docx

最终代码如下:

汇总了批量替换、彩色邮件、多附件功能

Public Declare Function SetTimer Lib "user32" _
        (ByVal hwnd As Long, ByVal nIDEvent As Long, ByVal uElapse As Long, ByVal lpTimerfunc As Long) As Long
Public Declare Function KillTimer Lib "user32" _
        (ByVal hwnd As Long, ByVal nIDEvent As Long) As Long
Private Declare Sub Sleep Lib "kernel32" (ByVal dwMilliseconds As Long)

Function WinProcA(ByVal hwnd As Long, ByVal uMsg As Long, ByVal idEvent As Long, ByVal SysTime As Long) As Long
    KillTimer 0, idEvent
    DoEvents
    Sleep 100
    ‘使用Alt+S发送邮件,这是本文的关键之处,免安全提示自动发送邮件全靠它了
    Application.SendKeys "%s"
End Function

‘ 发送单个邮件的子程序
Sub SendMail(ByVal to_who As String, ByVal subject As String, ByVal body As String, ByVal attachement As String)
    Dim objOL As Object
    Dim itmNewMail As Object
    Dim attaches
    Dim attach

    ‘引用Microsoft Outlook 对象
    Set objOL = CreateObject("Outlook.Application")
    Set itmNewMail = objOL.CreateItem(olMailItem)
    With itmNewMail
        .subject = subject  ‘主旨
        .HTMLbody = body   ‘正文本文
        .To = to_who  ‘收件者
        .Display  ‘启动Outlook发送窗口
        attaches = Split(attachement, ";")

        For Each attach In attaches
            If (Len(attach) > 0) Then
                .Attachments.Add attach
            End If
        Next
        SetTimer 0, 0, 0, AddressOf WinProcA
    End With

    Set objOL = Nothing
    Set itmNewMail = Nothing
End Sub

‘批量发送邮件
Sub BatchSendMail()
    Dim rowCount, endRowNo
    Dim newBody
    Dim replaceCount, maxReplaceCount
    Dim pattern
    endRowNo = Cells(1, 1).CurrentRegion.Rows.Count

    ‘逐行发送邮件
    For rowCount = 1 To endRowNo
        ‘ 替换当前行模板内容
        maxReplaceCount = 2   ‘ 有几处替换就写几。例子中有两处,就写2
        newBody = Cells(rowCount, 3)

        For replaceCount = 1 To maxReplaceCount
            pattern = "[==" & CStr(replaceCount) & "==]"
            newBody = WorksheetFunction.Substitute(newBody, pattern, Cells(rowCount, 4 + replaceCount))
        Next
        ‘ 替换好了,发邮件咯!
        SendMail Cells(rowCount, 1), Cells(rowCount, 2), newBody, Cells(rowCount, 4)

    Next
End Sub

参考文献:

tid=53888">http://www.officefans.net/cdb/viewthread.php?tid=53888

本文发送邮件过程中不会弹出安全提示框。发件速度极快;)

网友反馈:

  • 发件人:angel3814
  • 时间:2013-01-28 10:35:30

您好,经过测试,该方法对于大量发送邮件(大于100封。几十封没有问题。

)有一些问题,因为程序必须在建立完成所有word发送窗口后。才会统一alt+S发送,很容易造成内存不足,并且。最后的alt+S便不再执行。在实际应用中,我只能再写一个按钮,每次发送5封,发送完成计数+5,手工再点;想跟您请教,是否能有更好的改进方法?

非常感谢angel3814提供的解决方案:

Sub BatchSendMail()
    Dim rowCount, endRowNo, csheet As Worksheet, ssheet As Worksheet, i As Integer, j As Integer
    endRowNo = Cells(1, 1).CurrentRegion.Rows.Count
    ‘逐行发送邮件
    Set csheet = Worksheets("邮件内容")
    Set ssheet = Worksheets("发送")
    i = ssheet.Cells(2, 1).Value
    j = ssheet.Cells(2, 2).Value

    For rowCount = i To j
        SendMail csheet.Cells(rowCount, 1), csheet.Cells(rowCount, 2), csheet.Cells(rowCount, 3), csheet.Cells(rowCount, 4)
    Next
    ssheet.Cells(2, 1).Value = i + 5
    ssheet.Cells(2, 2).Value = j + 5
End Sub

点一次,自动+5。再点

之所以用5,是测试发现,10以上。就有很大几率alt+S事件不生效(可能还是延迟问题?)

====

另外。对于希望批量发送邮件的同学。可以不用把思维局限在Outlook上。如果你知道公司的邮件服务器的pop3地址。不妨用命令行工具自动发送大量的电子邮件。

例如:Blat:http://www.blat.net/syntax/syntax.html

准备使用任何工具发送电子邮件信件。将其保存为文本文件,然后Blat发送到循环逐个。

时间: 2024-11-25 14:59:59

使用Excel快速发送大量的电子邮件的相关文章

EXCEL快速自动填充方法集锦

EXCEL快速自动填充方法集锦 原文地址,转载请注明:http://www.cnblogs.com/croso/p/5396841.html 方法一: 名称框输入a1:a1000回车,1, ctrl+回车,单击A1,双击填充柄,“自动填充选项”--“填充序列” 方法二: 先在A1输入需填充的内容,然后点右上角的填充按钮,点击“系列”选项,输入终止值 方法三: 编辑 定位 输入需要输入数据的最后一个单元格的位置ctrl ↑(方向键的上箭头) 编辑栏输入公式=MOD(ROW()-1,2)+1按ctr

企业信息化-Excel快速生成系统

企业信息化,主要是指对企业生产运营过程所形成的信息数字化,最终形成了数字资产.大型企业为了节约成本,提高协同工作效率,都会定制ERP.办公OA.流程审批等系统做信息化支撑.但是中小企业精力投入到生成中,对信息化也有需求,但是因为各种原因不能投入的信息系统的建设,主要原因有: 1.资金申请难:一套软件系统,从几万到几十万都有,在成长的企业主要资金投入到生成过程,不能有太多的资金投入: 2.需求满足难:每个企业都有自己的规则和灵活处理的机制,并且随着政策和外部环境的变化,企业内部信息需求处理也是不断

Excel快速打印底端标题,教你一招,肯定行!

pdf技巧之家 2018-11-10 11:06:00今天跟大家分享一个关于Excel如何快速打印底端标题的技巧,需要的赶紧学起来! 方法步骤: 首先我们在工作表中输入底部要显示的标题文字,然后使用截图工具把这部分文字截图保存为图片,接下来将工作表中的底端标题文字清除掉. 点击工具栏[页面布局]--[打印标题]--[页面设置].单击[顶端标题行],然后编辑右侧的折叠按钮,单击第一行的行号,这样就轻松选中了第一行作为顶端标题行. 点击[页眉/页脚]--[自定义页脚],打开[页脚]对话框,单击[中]

Excel快速删除空白行与调整行高列宽的方法,学会了很实用

Excel表格作为大家经常使用的办公文档,在使用的过程中我们也会遇到各种问题,比如常见的行高列宽的调整.空白行的删除的等等.今天小编就为大家带来了Excel快速删除空白行与行高列宽的方法,希望可以帮助到大家. 一:调整行高列宽 作为Excel表格最常见的问题之一,我们在办公中常用到的调整行高列宽的方法主要有两种,都非常的简单方便. 方法1: 第一种方法也是最简单的一种方法,把鼠标光标放置在行高或者是列宽线条上时,就会出现一个[黑色双箭头]的标志,点击即可拉动线条调整行高.列宽.(唯一的弊端是行高

使用excel快速制表 拒绝粗心

办公室打印个表格 使用了word打印后 发现 id重复很多 只好网上找了点excel 2003资料 学习小 ①快速制作表格 新建一个excel文件. 在新建excel中,用鼠标选中需要的表格行数列数,然后点右键,“设置单元格格式”——“边框”,在“预置”中根据需要选择“外边框”.“内部”边框. 根据需要加边框.如果是标题处,可以取消外边框,合并横向或者纵向的表格.方法也是先选中需要设置的表格(第一行),然后右键点击“设置单元格格式”——“对齐”,然后选中“合并单元格”. EXCEL中设置固定的表

Python SMTP 发送带附件电子邮件

起始于对现有工作的内容进行部分重复工作的释放,花费了两周的时间调试了完全可能自己吼得住看得懂能实现目标的代码,如标题所说,本代码主要用户带附件的电子邮件的发送:对于代码大家只需要修改下文件路径,邮箱地址即可运行,我这边主要是结合navicat数据导出之后+此发送邮件的代码,做成定时任务,让程序每天按时执行,大家就不需要再每天去导数据了,让程序来完成即可,不是有句话怎么说来着:懒人自动化 人越懒才会去想着怎么去做成自动化 安于现状的往往不会有很多的想法说了这么多废话,直接给大家看下面的代码:# e

Excel快速改变行列的次序

改变行列次序是在Excel中常常需要进行的操作,多数用户的方法是先剪切要调整的行或列,然后选定目标位置,单击菜单“插入”→“剪切单元格”. 事实上,使用键盘来配合的话,改变行列的次序可以更快捷.比如,在图1所示的表中,我们要把C列的数据放到B列前面去. 图 1 需要改变列次序的数据表 Step 1 单击C列列表,选定整列. Step 2 把光标移动到C列右侧的黑色边框上,按住Shift键,开始往左拖动.这时我们可以看到光标左侧出现一条T字形虚线,如图2所示. 图2 拖动T字形虚线 Step 3

nodejs实现,每天定时自动读取数据库数据-生成excel表格-发送给老板邮箱(promise版)

async版:http://blog.csdn.net/zzwwjjdj1/article/details/52129192 写这个版本主要是,promise比较好用,而且,现在已经是nodejs的内置对象了,无须再引用第三方库 -- 需要的工具 数据库    mysql 连接数据库模块 mysql  基本封装: http://blog.csdn.net/zzwwjjdj1/article/details/51991348 自动运行模块   node-schedule 基本使用 : http:/

分享知识-快乐自己:Excel快速导入Oracle 数据库

需求: oracle 数据库有一个student表,现有一个excel表:student.xlsx,需导入oracle数据库student表中. student表的拥有者是c##MLQ1  密码为:xxx 表结构: 打开需导入的excel表格,单击office按钮,选择另存为--其他格式 选择保存路径(置于D:\),保存类型CSV(逗号分隔)(*.csv),设置文件名为student.csv,单击保存   新建input.ctl文件(置于D:\),内容为: load data infile 'd