人がエクセルに集計しメール送付していた作業をpythonで自動化したいと考えています。
集計したデータをエクセルファイルにまとめてメールに添付し送付するまではできたのですが、
メールに添付するエクセルファイルがどうしても日本語で指定してもAT****.xlsxになり
指定したファイル名で添付することができません。
メールヘッダでの添付ファイル名を記載する文字コード指定の方法
(ソース:filename = '添付ファイル名.xlsx')の箇所が問題と思われるのですが、
ネット、本等で調べても情報がなく手詰まりになっています。
正しい記載を知っている方は教えていただけないでしょうか。
該当のソースコード
言語 python3
OS centos7
import sys
import smtplib
from email.mime.text import MIMEText
from email.utils import formatdate
from email.generator import Generator
from email.message import EmailMessage
from_addr = "hagehoge@maile.com"
PASSWORD = "pass"
to_addr = "hagehoge@maile.com"
BODY = """
メール本文
ご確認ください
"""
SUBJECT = "エクセルファイル送付"
def create_message(from_addr, to_addr, subject, body, mime=None, attach_file=None):
msg=EmailMessage()
msg.set_content(body)
msg["Subject"] = subject
msg["From"] = from_addr
msg["To"] = to_addr
msg["Date"] = formatdate(localtime=True)
if mime != None and attach_file != None: filename = '添付ファイル名.xlsx' file = open(attach_file['path'],'rb') file_read = file.read() msg.add_attachment(file_read, maintype=mime['type'],subtype=mime['subtype'],filename=fname) file.close() return msg
def send(from_addr, to_addrs, msg):
smtpobj = smtplib.SMTP("mail.hage.com", 25)
smtpobj.ehlo()
smtpobj.login(from_addr, PASSWORD)
smtpobj.sendmail(from_addr, to_addr, msg.as_string())
smtpobj.close()
if name == 'main':
#添付ファイル設定(text.txtファイルを添付) mime={'type':'application', 'subtype':'vnd.openxmlformats-officedocument.spreadsheetml.sheet'} attach_file={'name':'添付ファイル名.xlsx', 'path':'添付ファイル名.xlsx'} #メッセージの作成(添付ファイルあり) msg = create_message(from_addr, to_addr, SUBJECT, BODY, mime, attach_file) #送信 send(from_addr, to_addr, msg)
回答1件
あなたの回答
tips
プレビュー