メール送信(Python を使用)

目次

1. 概要

Python で,SMTP サーバーを使用してメールを送信する方法を説明する。

Python の標準ライブラリ(smtplibemail.mime.textemail.utils)を使用し,SMTP サーバー経由でメールを送信する。単一宛先への送信,複数宛先への一括送信,CC・BCC を指定した送信を扱う。

2. Python 3.12 のインストール

本章では、Pythonのインストールを行い、Pythonのプログラムを実行する環境を整える。扱う環境は、Windows搭載パソコンである。金子研究室では、Python 3.12.10を推奨する。

[Windows での Python 3.12 のインストール手順を見るには、ここをクリック]

Windows での Python 3.12 のインストール

以下のいずれかの方法でPython 3.12をインストールする。Pythonがインストール済みの場合、この手順は不要である。

方法 1:winget によるインストール

インストールコマンドの実行方法

管理者権限コマンドプロンプトを起動する(手順:Windowsキーまたはスタートメニュー → cmd と入力 → 右クリック → 「管理者として実行」)。そして、コマンド全体をコマンドプロンプトにコピー&ペーストする。

--scope machine を指定することで、システム全体(全ユーザー向け)にインストールされる。このオプションの実行には管理者権限が必要である。インストール完了後、コマンドプロンプトを再起動するとPATHが反映される。

REM Python 3.12 をシステム領域にインストール
winget install --id Python.Python.3.12 -e --scope machine --silent --accept-source-agreements --accept-package-agreements --override "/quiet InstallAllUsers=1 PrependPath=1 Include_test=0 Include_pip=1 Include_launcher=1 InstallLauncherAllUsers=1 TargetDir=\"C:\Program Files\Python312\""

REM Python と Scripts を PATH 先頭に追加
powershell -NoProfile -Command "$p='C:\Program Files\Python312'; $s=\"$p\Scripts\"; $c=[Environment]::GetEnvironmentVariable('Path','Machine'); if((Test-Path $p) -and (';'+$c+';' -notlike \"*;$p;*\") -and (';'+$c+';' -notlike \"*;$s;*\")){[Environment]::SetEnvironmentVariable('Path',\"$p;$s;$c\",'Machine')}"

方法 2:インストーラーによるインストール

  1. Python公式サイト(https://www.python.org/downloads/)にアクセスし、「Download Python 3.x.x」ボタンからWindows用インストーラーをダウンロードする。
  2. ダウンロードしたインストーラーを実行する。
  3. 初期画面の下部に表示される「Add python.exe to PATH」にチェックを入れてから「Customize installation」を選択する。このチェックを入れ忘れると、コマンドプロンプトから python コマンドを実行できない。
  4. 「Install Python 3.xx for all users」にチェックを入れ、「Install」をクリックする。

インストールの確認

コマンドプロンプトで以下を実行する。

python --version

バージョン番号(例:Python 3.12.x)が表示されればインストール成功である。「'python' は、内部コマンドまたは外部コマンドとして認識されていません。」と表示される場合は、インストールが正常に完了していない。

以降の章では、必要に応じて題材に応じたソフトウェアを追加する。

3. Python の開発環境 Visual Studio Code のインストールと Python 用の設定

本章では、Python の開発環境Visual Studio Code(プログラムを編集するソフトウェア。以下、VS Code)を整える。

[Windows での Visual Studio Code のインストールと Python 用の設定手順を見るには、ここをクリック]

Windows での Visual Studio Code のインストールと Python 用の設定手順

1. VS Code と拡張機能のインストール

以下のコマンドにより,既存の VS Code を削除し,全ユーザー共有の設定で再インストールしたうえで,拡張機能(VS Code に機能を追加するソフトウェア)をまとめて導入する.

インストールコマンドの実行方法

管理者権限コマンドプロンプトを起動する(手順:Windows キーまたはスタートメニュー → cmd と入力 → 右クリック → 「管理者として実行」)。そして,コマンド全体をコマンドプロンプトにコピー&ペーストする。

インストールコマンド


REM ============================================================
REM Microsoft Visual Studio Code
REM ============================================================
winget uninstall -e --id Microsoft.VisualStudioCode --silent --disable-interactivity --accept-source-agreements
rmdir /s /q C:\ProgramData\vscode-extensions 2>nul
rmdir /s /q "%APPDATA%\Code" 2>nul
rmdir /s /q "%USERPROFILE%\.vscode" 2>nul
rmdir /s /q "%LOCALAPPDATA%\Microsoft\vscode-update" 2>nul

REM VS Code をシステム領域に新規インストール
winget install --scope machine --id Microsoft.VisualStudioCode -e --silent --accept-source-agreements --accept-package-agreements

REM 全ユーザー共有の拡張機能フォルダ
mkdir C:\ProgramData\vscode-extensions 2>nul
icacls "C:\ProgramData\vscode-extensions" /grant "Everyone:(OI)(CI)M" /T

REM スタートメニューのショートカットを --extensions-dir 付きで再作成
rmdir /s /q "C:\ProgramData\Microsoft\Windows\Start Menu\Programs\Visual Studio Code" 2>nul
del "C:\ProgramData\Microsoft\Windows\Start Menu\Programs\Visual Studio Code.lnk" 2>nul
powershell -NoProfile -Command "$s=New-Object -ComObject WScript.Shell; $lnk=$s.CreateShortcut('C:\ProgramData\Microsoft\Windows\Start Menu\Programs\Visual Studio Code.lnk'); $lnk.TargetPath='C:\Program Files\Microsoft VS Code\Code.exe'; $lnk.Arguments='--extensions-dir \"C:\ProgramData\vscode-extensions\"'; $lnk.Save()"
REM ショートカットの検証
powershell -NoProfile -Command "$s=New-Object -ComObject WScript.Shell; $lnk=$s.CreateShortcut('C:\ProgramData\Microsoft\Windows\Start Menu\Programs\Visual Studio Code.lnk'); Write-Host 'TargetPath:' $lnk.TargetPath; Write-Host 'Arguments:' $lnk.Arguments"

REM ファイル / フォルダ右クリックの「Code で開く」を登録
reg add "HKLM\SOFTWARE\Classes\*\shell\VSCode\command" /ve /d "\"C:\Program Files\Microsoft VS Code\Code.exe\" --extensions-dir \"C:\ProgramData\vscode-extensions\" \"%1\"" /f
reg add "HKLM\SOFTWARE\Classes\Directory\shell\VSCode\command" /ve /d "\"C:\Program Files\Microsoft VS Code\Code.exe\" --extensions-dir \"C:\ProgramData\vscode-extensions\" \"%1\"" /f
reg add "HKLM\SOFTWARE\Classes\Directory\Background\shell\VSCode\command" /ve /d "\"C:\Program Files\Microsoft VS Code\Code.exe\" --extensions-dir \"C:\ProgramData\vscode-extensions\" \"%V\"" /f

REM --extensions-dir 付きで起動する code.cmd ラッパを作成
REM (%* を echo で書くと対話的 cmd で失われるため、PowerShell で [char]37+'*' を書き出す)
powershell -NoProfile -Command "$pct=[char]37; $q=[char]34; $c='@echo off'+[char]13+[char]10+$q+'C:\Program Files\Microsoft VS Code\bin\code.cmd'+$q+' --extensions-dir '+$q+'C:\ProgramData\vscode-extensions'+$q+' '+$pct+'*'+[char]13+[char]10; [IO.File]::WriteAllText('C:\ProgramData\vscode-extensions\vscode.cmd',$c,[Text.Encoding]::ASCII)"

REM 拡張機能のインストール
set "CODE=C:\Program Files\Microsoft VS Code\bin\code.cmd"
"%CODE%" --extensions-dir "C:\ProgramData\vscode-extensions" --uninstall-extension GitHub.copilot
"%CODE%" --extensions-dir "C:\ProgramData\vscode-extensions" --uninstall-extension GitHub.copilot-chat
"%CODE%" --extensions-dir "C:\ProgramData\vscode-extensions" --install-extension ms-python.python
"%CODE%" --extensions-dir "C:\ProgramData\vscode-extensions" --install-extension ms-python.vscode-pylance
"%CODE%" --extensions-dir "C:\ProgramData\vscode-extensions" --install-extension ms-python.debugpy
"%CODE%" --extensions-dir "C:\ProgramData\vscode-extensions" --install-extension MS-CEINTL.vscode-language-pack-ja
"%CODE%" --extensions-dir "C:\ProgramData\vscode-extensions" --install-extension saoudrizwan.claude-dev
"%CODE%" --extensions-dir "C:\ProgramData\vscode-extensions" --install-extension rust-lang.rust-analyzer
"%CODE%" --extensions-dir "C:\ProgramData\vscode-extensions" --install-extension tamasfe.even-better-toml
"%CODE%" --extensions-dir "C:\ProgramData\vscode-extensions" --install-extension anthropic.claude-code
"%CODE%" --extensions-dir "C:\ProgramData\vscode-extensions" --install-extension almenon.arepl
"%CODE%" --extensions-dir "C:\ProgramData\vscode-extensions" --list-extensions --show-versions
echo === セットアップ完了 ===

2. Python インタプリタの選択

同一マシンに複数の Python がインストールされている場合,VS Code で使用する Python 本体(インタプリタ:Python プログラムを解釈・実行するソフトウェア)を選択する必要がある.

  1. コマンドパレット(コマンド名で機能を呼び出す VS Code の入力欄)を開く(Ctrl+Shift+P
  2. Python: Select Interpreter と入力する
  3. 表示される一覧から,使用する Python(例:C:\Program Files\Python312\python.exe)を選択する.

以降の章では、必要に応じて題材に応じた必要なソフトウェアを追加する。

4. Python プログラム実行手順

[Windows での Python プログラム実行手順を見るには、ここをクリック]

Windows での Python 実行手順(Visual Studio Codeを使用)

プログラムファイルの作成と保存

  1. 左サイドバーの「エクスプローラー」アイコン(Ctrl+Shift+E)をクリックする
  2. 「NO FOLDER OPENED」(作業対象フォルダが未選択の状態)と表示される場合は,「Open Folder」をクリックし,プログラムを保存するフォルダを選択する

    続いて「フォルダを信用するか」を確認する画面(フォルダ内のコードを実行してよいか確認する VS Code の仕組み)が表示されるので,チェックして Yes を選択する

  3. フォルダ名の右側に表示される「新しいファイル」アイコンをクリックする
  4. ファイル名(例:aitask.py.ファイル名は何でも良い)を入力し Enter を押す.拡張子は .py(Python ファイルを示す拡張子)とする
  5. 実行したいコードを選択し,Ctrl+C でコピーする.VS Code のエディタ領域に Ctrl+V で貼り付ける
  6. Ctrl+S で保存する

プログラムの実行

  1. エディタ右上の三角形「▷」アイコン(Run Python File:現在開いている Python ファイルを実行するボタン)をクリックする.または,エディタ上で右クリックし「ターミナルで Python ファイルを実行」を選択する
  2. VS Code 下部のターミナル(コマンドの入出力を表示する画面)に,実行結果(print 関数の出力等)が表示される
  3. tkinter(Python 標準の GUI ライブラリ)のファイル選択ダイアログを使うプログラムを実行した場合は,ダイアログが開くので対象画像を選択する
  4. VS Code 下部のターミナルで実行結果を確認する.OpenCV ウィンドウ(OpenCV が画像を表示するために開く専用ウィンドウ)が開いた場合はそちらも確認する.OpenCV ウィンドウは,マウスクリックでウィンドウをアクティブ(操作対象の状態)にしてからキーを押すと終了する

本プログラムが使用する smtplibemail.mime.textemail.utils はすべて Python 標準ライブラリであるため,追加のライブラリインストールは不要である。

5. 実行のための準備とその確認手順(Windows 前提)

5.1 プログラムファイルの準備

第7章のソースコードをテキストエディタ(Visual Studio Code やメモ帳など)に貼り付け,hoge.py として保存する(文字コード:UTF-8)。

5.2 実行コマンド

コマンドプロンプトでファイルの保存先ディレクトリに移動し,以下を実行する。

python hoge.py

5.3 動作確認チェックリスト

確認項目期待される結果
SMTP サーバーへの接続指定した SMTP サーバー(ポート587)に接続し,STARTTLS で暗号化通信が確立される
認証指定したユーザー名・パスワードで SMTP サーバーへのログインが成功する
メール送信(単一宛先)指定した宛先にメールが送信され,件名・本文・送信日時が正しく設定されている
メール送信(複数宛先・CC・BCC)複数宛先への一括送信,CC・BCC を指定した送信がそれぞれ正しく動作する

6. 概要・使い方・実行上の注意

本プログラムは,smtplib を使用して SMTP サーバー経由でメールを送信する。STARTTLS による暗号化通信を行い,ユーザー名とパスワードで認証したうえで送信する。

使用前に,以下の変数を利用環境に合わせて書き換える。

変数名設定内容
UNAMESMTP 認証用のユーザー名(メールアドレス)
PASSWORDSMTP 認証用のパスワード
SMTP_SERVERSMTP サーバーのホスト名
FROM_ADDR送信元メールアドレス
TO_ADDR / TO_ADDRS宛先メールアドレス(単一は文字列,複数はリスト)
CC_ADDRSCC 宛先メールアドレスのリスト
BCC_ADDRSBCC 宛先メールアドレスのリスト
SUBJECTメールの件名
BODYメールの本文

3種類の送信方法を提供する。

単一宛先への送信:mysendmail 関数を使用する。MIMEText でメッセージを構築し,Subject,From,To,Date の各ヘッダを設定して送信する。

複数宛先への一括送信:mysendmail_multiple 関数を使用する。宛先をリストで指定することで,同一内容のメールを複数の宛先へ一括送信できる。sendmail メソッドの第2引数にリストを渡すと,リスト内の全アドレスに送信される。

CC・BCC を指定した送信:mysendmail_cc_bcc 関数を使用する。CC(Carbon Copy,カーボンコピー)はヘッダに宛先として表示される。BCC(Blind Carbon Copy,ブラインドカーボンコピー)はヘッダに記載されないため,他の受信者からは見えない。sendmail メソッドには,To・CC・BCC を含む全受信者のリストを渡す。

ソースコードは第7章に掲載する。

7. ソースコード

7.1 単一宛先への送信

import smtplib
from email.mime.text import MIMEText
from email.utils import formatdate

def mysendmail(uname, password, smtp_server, from_addr, to_addr, subject, body):
    msg = MIMEText(body)
    msg['Subject'] = subject
    msg['From'] = from_addr
    msg['To'] = to_addr
    msg['Date'] = formatdate()
    with smtplib.SMTP(smtp_server, 587) as sv:
        sv.starttls()
        sv.login(uname, password)
        sv.sendmail(from_addr, to_addr, msg.as_string())

UNAME = "user@hoge.com"
PASSWORD = "pass"
SMTP_SERVER = "mailsv.hoge.com"
FROM_ADDR = "user@hoge.com"
TO_ADDR = "other@hoge.com"
SUBJECT = "タイトル"
BODY = "メッセージ本文"

if __name__ == '__main__':
    mysendmail(UNAME, PASSWORD, SMTP_SERVER, FROM_ADDR, TO_ADDR, SUBJECT, BODY)

7.2 複数の宛先への一括送信

import smtplib
from email.mime.text import MIMEText
from email.utils import formatdate

def mysendmail_multiple(uname, password, smtp_server, from_addr, to_addrs, subject, body):
    msg = MIMEText(body)
    msg['Subject'] = subject
    msg['From'] = from_addr
    msg['To'] = ", ".join(to_addrs)
    msg['Date'] = formatdate()
    with smtplib.SMTP(smtp_server, 587) as sv:
        sv.starttls()
        sv.login(uname, password)
        sv.sendmail(from_addr, to_addrs, msg.as_string())

UNAME = "user@hoge.com"
PASSWORD = "pass"
SMTP_SERVER = "mailsv.hoge.com"
FROM_ADDR = "user@hoge.com"
TO_ADDRS = ["other1@hoge.com", "other2@hoge.com", "other3@hoge.com"]
SUBJECT = "タイトル"
BODY = "メッセージ本文"

if __name__ == '__main__':
    mysendmail_multiple(UNAME, PASSWORD, SMTP_SERVER, FROM_ADDR, TO_ADDRS, SUBJECT, BODY)

7.3 CC・BCC を指定した送信

import smtplib
from email.mime.text import MIMEText
from email.utils import formatdate

def mysendmail_cc_bcc(uname, password, smtp_server, from_addr, to_addr, cc_addrs, bcc_addrs, subject, body):
    msg = MIMEText(body)
    msg['Subject'] = subject
    msg['From'] = from_addr
    msg['To'] = to_addr
    msg['Cc'] = ", ".join(cc_addrs)
    msg['Date'] = formatdate()
    all_recipients = [to_addr] + cc_addrs + bcc_addrs
    with smtplib.SMTP(smtp_server, 587) as sv:
        sv.starttls()
        sv.login(uname, password)
        sv.sendmail(from_addr, all_recipients, msg.as_string())

UNAME = "user@hoge.com"
PASSWORD = "pass"
SMTP_SERVER = "mailsv.hoge.com"
FROM_ADDR = "user@hoge.com"
TO_ADDR = "other@hoge.com"
CC_ADDRS = ["cc1@hoge.com", "cc2@hoge.com"]
BCC_ADDRS = ["bcc1@hoge.com"]
SUBJECT = "タイトル"
BODY = "メッセージ本文"

if __name__ == '__main__':
    mysendmail_cc_bcc(UNAME, PASSWORD, SMTP_SERVER, FROM_ADDR, TO_ADDR, CC_ADDRS, BCC_ADDRS, SUBJECT, BODY)

8. まとめ

smtplib による SMTP 通信
標準ライブラリ smtplib を使用し,SMTP サーバー(ポート587)に接続する。STARTTLS で暗号化通信を行い,with 文で接続の終了処理を自動化する。

MIMEText によるメッセージ構築
MIMEText でメールメッセージを構築し,Subject,From,To,Date の各ヘッダを設定する。as_string() で文字列に変換して送信する。

複数宛先への一括送信
宛先をリストで指定し,sendmail メソッドの第2引数にリストを渡すことで,同一内容のメールを複数の宛先へ一括送信する。

CC・BCC の指定
CC はヘッダに宛先として表示される。BCC はヘッダに記載されないため,他の受信者からは見えない。sendmail メソッドには To・CC・BCC を含む全受信者のリストを渡す。

SMTP 認証
SMTP サーバーへの接続後,ユーザー名とパスワードで login メソッドにより認証を行い,メールを送信する。