Djangoで、データベースに登録されたメールアドレス宛にメールを送信するアプリを作りたいのですが、models.pyと同じ階層にあるsend_mail.pyでデータベースのデータを使うにはどうすればいいのでしょうか。
send_mail.pyのTO_ADDRESSの'????????'にデータベース内の全てのメールアドレスをfor文のように一つずつ入れて全員にメールを送りたいと思っております。
下のコードはsend_mail.pyです。
python
1import schedule 2import time 3import smtplib 4from email.mime.text import MIMEText 5from email.utils import formatdate 6import ssl 7 8 9FROM_ADDRESS = '****@gmail.com' 10MY_PASSWORD = '****' 11TO_ADDRESS = '????????' 12BCC = '' 13SUBJECT = '送信テスト' 14BODY = '送信テストです' 15 16def create_message(from_addr, to_addr, bcc_addrs, subject, body): 17 msg = MIMEText(body) 18 msg['Subject'] = subject 19 msg['From'] = from_addr 20 msg['To'] = to_addr 21 msg['Bcc'] = bcc_addrs 22 msg['Date'] = formatdate() 23 return msg 24 25def send(from_addr, to_addrs, msg): 26 #context = ssl.create_default_context() 27 smtpobj = smtplib.SMTP_SSL('smtp.gmail.com', 465, timeout=10) 28 smtpobj.login(FROM_ADDRESS, MY_PASSWORD) 29 smtpobj.sendmail(from_addr, to_addrs, msg.as_string()) 30 smtpobj.close() 31 32if __name__ == '__main__': 33 34 to_addr = TO_ADDRESS 35 subject = SUBJECT 36 body = BODY 37 38 msg = create_message(FROM_ADDRESS, to_addr, BCC, subject, body) 39 send(FROM_ADDRESS, to_addr, msg) 40 41 schedule.every(1/60).minutes.do(send, FROM_ADDRESS, to_addr, msg) 42 43 while True: 44 schedule.run_pending() 45 time.sleep(1)
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。