HOME技術ExcelExcel VBA:メールを送信する

Excel VBA:メールを送信する

Excel VBAからメールを送信するボタンをつくります。
パスワードロックをかけたブックを利用していて、パスワードがわからなくなったらメールを送信してパスワードを教える機能を付けようと思い、調べました。
調べた後に、パスワードロックをしても突破する方法がいくつもあることを知り、パスワードロックをかけること自体無意味なことかと考えています…

CDO(Microsoft Collaboration Data Objects)を使用可能にする

「開発」メニューよりデザインモードにして、「挿入」→「ActivXコントロール」→「コマンドボタン(ActiveXコントロール)」を設置します。
右クリックしてプロパティを開いて、オブジェクト名を「sendMail」、Captionを「メール送信」にします。

デザインモードのまま、配置したボタンをダブルクリックしてVBAのコード入力画面を開きます。

「ツール」→「参照設定」を指定します。

「参照可能なライブラリファイル」の一覧から「Microsoft CDO for Windows 2000 Library」にチェックを入れて、「OK」をクリックします。

コード

Dim sendMailObject As New CDO.Message
With sendMailObject
With .Configuration.Fields
.Item(cdoSMTPServer) = “xxx.xxx.xxx” ‘ SMTPサーバ
.Item(cdoSendUsingMethod) = “cdoSendUsingPort”
.Item(cdoSMTPServerPort) = 587 ‘ 送信ポート名
.Item(cdoSMTPConnectionTimeout) = 60 ‘ タイムアウト時間
.Item(cdoSMTPAuthenticate) = cdoBasic ‘ SMTP認証の種類
.Item(cdoSMTPUseSSL) = False ‘ SSL
.Item(cdoSendUserName) = “xxxxxxx” ‘ 送信ユーザアカウント名
.Item(cdoSendPassword) = “xxxxxx” ‘ 送信パスワード
.Item(cdoLanguageCode) = CdoCharset.cdoShift_JIS ‘ 文字コード
.Update
End With
With .Fields
.Item(“urn:schemas:mailheader:X-Priority”)= 1
.Item(“urn:schemas:mailheader:X-MsMail-Priority”)= “High”
.Update
End With
.MDNRequested = False ‘ 開封確認
.MimeFormatted = True ‘ MIMEを使った書式設定
.From = “xxx@xxx.xxx” ‘ 送信元メールアドレス
.To = “xxx@xxx.xxx” ‘ 宛先メールアドレス
.Subject = “xxxxxx” ‘ メール件名
.TextBody = “xxxxx” ‘ メール本文
.Send
End With
Set sendMailObject = Nothing
End Sub

メール送信をする際には、送信用のユーザアカウント、パスワード、SMTPサーバ名が必要です。
cdoSMTPUseSSLはSSLを使った送信をするか否かを指定するものです。
SSLを使う場合にはTrueを指定しますが、エラーが出る場合もあります。
送信元メールアドレスは、架空のメールアドレスでもいいので、xxx@xxx.xxxという形式の指定をします。指定がおかしいとエラーが出ます。

関連記事

Excel:別のExcelファイルの値を参照したファイル

Excelでは、別のExcelファイルの値を参照させることができます。 その際、2つのExcelを開いておき、一方から他方のセルをクリックすることで参照させることができます。 このとき、参照先のExc…続きを読む

Excel VBA:最終行番号を取得する

Excelでデータ管理をしていて、VBAでその全データに対して何らかの処理を行う場合、1行目から最終行までループさせて処理を1行ずつ行う場合には、最終行を取得する必要があります。 今回は、最終行を取得…続きを読む

Excelで数字をコピーしたときに連番にならない

Excelで数字が入力されているセルの右下にマウスカーソルを合わせて、下にコピーしていくと、通常は数字が1つずつ足された連番の値でコピーされていきます。 それが何度やっても、何をやっても連番にならなか…続きを読む

Excel:「このファイルのソースが信頼できないため、Microsoftによりマクロの実行がブロックされました」と表示される

メールに添付されたマクロ付きExcelファイルを開いたところ、 「このファイルのソースが信頼できないため、Microsoftによりマクロの実行がブロックされました」と表示され、マクロが実行できなくなっ…続きを読む

Excel VBAでログイン管理をする

Excelを開いたときに「閲覧のみ」ユーザか「管理者」ユーザかを選び、「閲覧のみ」ユーザの場合にはExcelを閉じるときに保存できないようにして、「管理者」ユーザの場合には、Excelを閉じるときに変…続きを読む

Excel:ハイパーリンクで別ファイルを開く

Excelにおいて、別ファイルにハイパーリンクを付けて、リンクをクリックすると指定したファイルが開くようにします。 通常のハイパーリンクの作成の場合だと、セルの上で右クリック→「リンク」をクリックして…続きを読む

Excelで複数部印刷しようとしても指定部数印刷されない

Excelを開いて複数部印刷しようとしても、指定部数が印刷されない不具合への対処法です。 例えば、5部印刷しようとしても、1部ないしは2部しか印刷されません。 そして、エラーメッセージとして「【プリン…続きを読む

Excelのフォームのタブオーダーを指定する

Excelでフォームを設定し、部品を複数配置していると、タブキーやEnterキーを押すと次の部品にフォーカスを飛ばすことができます。 この順序が意図したとおりでない場合に、自分で設定する方法を調べまし…続きを読む

Excel VBAでコマンドプロンプトを起動しコマンドを実行する

Excel VBAでコマンドプロンプトを起動し、かつコマンドを実行する方法です。 コマンドプロンプトの実行 コマンドプロンプトを実行するには以下のように書きます。 CreateObject (&#82…続きを読む

Exdel VBA:グローバル変数の指定

Excel VBAでグローバル変数を設定する方法です。 プロシージャ内で宣言した変数は、そのプロシージャ内でしか通用しません。 すべてのプロシージャから参照するような定数を設定する場合には、以下のよう…続きを読む