🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
Django

DjangoはPythonで書かれた、オープンソースウェブアプリケーションのフレームワークです。複雑なデータベースを扱うウェブサイトを開発する際に必要な労力を減らす為にデザインされました。

SQLite

SQLiteはリレーショナルデータベース管理システムの1つで、サーバーではなくライブラリとして使用されている。

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

Q&A

解決済

1回答

1034閲覧

Djangoのmodels.py内のデータベースのデータをmodels.pyと同じディレクトリのpyファイルで使いたい

omyu

総合スコア22

Django

DjangoはPythonで書かれた、オープンソースウェブアプリケーションのフレームワークです。複雑なデータベースを扱うウェブサイトを開発する際に必要な労力を減らす為にデザインされました。

SQLite

SQLiteはリレーショナルデータベース管理システムの1つで、サーバーではなくライブラリとして使用されている。

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

0グッド

0クリップ

投稿2019/10/03 14:08

編集2019/10/06 09:46

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)

下の画像はmodels.pyです
イメージ説明

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

自己解決

send_mail.pyをカスタムコマンドにすることによって、モデルからデータを引っ張って来れるようになりました。

投稿2019/10/12 08:17

omyu

総合スコア22

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.36%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問