目次
概要
Pythonで自動処理を行う中で、Outlookメールにファイルを添付して送信できたら便利だと感じたことはありませんか?
私自身、定型報告やファイル送信の自動化を考える中で、「Pythonからメールを送って、しかも添付ファイルもつけたい」と思い、今回その方法を学びました。
実現したい仕様
- OutlookのSMTPサーバーを使ってメールを送信
- 件名と本文は任意に設定可能
- ファイル(今回は
mori.xlsx)を添付する - Pythonから完全自動で送信する構成
実装コード(Python)
以下が、実際に動作したPythonのコードです。
import smtplib
from email.mime.multipart import MIMEMultipart
from email.mime.text import MIMEText
from email.mime.base import MIMEBase
from email import encoders
filename = "mori.xlsx"
# メール設定
subject = "Hello World"
body = "Hello World"
sender_email = "your-email@outlook.com"
receiver_email = "receiver-email@example.com"
password = "your-email-password"
# メールメッセージの作成
message = MIMEMultipart()
message["Subject"] = subject
message["From"] = sender_email
message["To"] = receiver_email
# 本文を追加
message.attach(MIMEText(body, "plain"))
# 添付ファイルを読み込み・エンコード
with open(filename, "rb") as attachment:
part = MIMEBase("application", "octet-stream")
part.set_payload(attachment.read())
encoders.encode_base64(part)
part.add_header(
"Content-Disposition",
f"attachment; filename= {filename}",
)
message.attach(part)
# SMTP接続(Outlook)
server = smtplib.SMTP("smtp-mail.outlook.com", 587)
server.starttls()
server.login(sender_email, password)
# メール送信
server.send_message(message)
server.quit()
コードの補足
smtplib.SMTPを使って、OutlookのSMTPサーバーに接続(ポート587でSTARTTLS)MIMEMultipart()を使用して、件名・本文・添付ファイルをまとめて構成- 添付ファイルは
MIMEBaseで読み込んでBase64でエンコード .send_message()で一発送信し、.quit()でセッションを終了
Outlook SMTPの設定ポイント
- サーバー:
smtp-mail.outlook.com - ポート:587
- 暗号化:STARTTLS(
server.starttls()) - 認証:Outlookアカウントのメールアドレスとパスワードを使用(2段階認証有効時はアプリパスワード)
まとめ
- Pythonを使えば、Outlook経由で添付ファイル付きメールの自動送信が可能です
MIMEMultipart+smtplibを組み合わせることで柔軟なメール構成ができる- 業務でのレポート配信や定型送信にも応用しやすい
技術書の購入コストを抑えてスキルアップするなら

ここまで読んでいただきありがとうございます。最後に宣伝をさせてください。
プログラミングの技術書や参考書は、1冊3,000円〜5,000円するものも多く、出費がかさみがちです。Kindle Unlimitedであれば、月額980円で500万冊以上の書籍が読み放題となります。
気になる言語の入門書から、アルゴリズム、基本設計の専門書まで、手元のスマホやPCですぐに参照可能です。現在は「30日間の無料体験」や、対象者限定の「3か月499円プラン」なども実施されています。まずはご自身のアカウントでどのようなオファーが表示されるか確認してみてください。
