質問をすることでしか得られない、回答やアドバイスがある。

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

新規登録して質問してみよう
ただいま回答率
85.35%
Django

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

Model

MVCモデルの一部であるModelはアプリケーションで扱うデータとその動作を管理するために扱います。

Webサイト

一つのドメイン上に存在するWebページの集合体をWebサイトと呼びます。

Python

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

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

Q&A

0回答

802閲覧

[至急] モデルフィールド間の計算とその表示

harug

総合スコア28

Django

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

Model

MVCモデルの一部であるModelはアプリケーションで扱うデータとその動作を管理するために扱います。

Webサイト

一つのドメイン上に存在するWebページの集合体をWebサイトと呼びます。

Python

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

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

0グッド

0クリップ

投稿2021/12/02 22:45

編集2021/12/05 22:25

前提・実現したいこと

Django上でWebアプリを作成しています。
具体的には、
お店の情報(店名、所在地、営業時間など)を登録 ⇒ ホーム画面で町名を選択、検索 ⇒ その町のお店の中で、現在営業しているお店のみを表示
というものをを作成しています。
そこで、登録された各店舗の営業時間の範囲の中に現在時刻が含まれていれば、そのお店を表示するという機能を実装時にmodels.pyのフィールド間の計算でよく分からないことがありました。

以下にソースコードと共に問題を説明いたします。

該当のソースコード

まずは、models.pyです。
★を付けたところをどのように書き換えるとよいのかが分かりませんでした。

python

1class ShopInfo(models.Model): 2 open_hour = models.IntegerField(verbose_name="開店時", default=0) #~時 3 open_min = models.IntegerField(verbose_name="開店分", default=0) #~分から 4 open_sec = models.IntegerField(verbose_name="開店秒", default=0) #★ 5 6 close_hour = models.IntegerField(verbose_name="閉店時", default=0) #~時 7 close_min = models.IntegerField(verbose_name="閉店分", default=0) #~分まで営業 8 close_sec = models.IntegerField(verbose_name="閉店秒", default=0) #★ 9 10 # 開店時間までに経過した秒数 11 def OpenSec(self, *args, **kwargs): #★ 12 self.open_sec = self.open_hour*60*60 + self.open_min*60 13 super(ShopInfo, self).OpenSec(*args, **kwargs) 14 15 # 閉店時間までに経過した秒数 16 def CloseSec(self, *args, **kwargs): #★ 17 self.close_sec = self.close_hour*60*60 + self.close_min*60 18 super(ShopInfo, self).CloseSec(*args, **kwargs) 19

次に、views.pyです。

models.pyのメソッドを消してコメントアウトしている部分を追加してみても結果はうまくいきませんでした。

python

1def ShopView(request,select_town): #今回はselect_townには引数としてishikawaが割り当てられた場合を考えます 2 now = datetime.datetime.now() 3 now_hour = now.hour 4 now_min = now.minute 5 6 towns = {"ishikawa":"石川町","etomo":"絵鞆町","kaigan":"海岸町","kagawa":"香川町","kamishiro":"神代町","kounan":"港南町","saiwai":"幸町"} 7 8 info = models.ShopInfo.objects.all() #すべてのオブジェクト 9 10 now_sec = now_hour*60*60 + now_min*60 #現在時刻まで何秒経過しているか 11 12 # open_sec = open_hour_sec*60*60 + open_min_sec*60 13 # open_sec = models.ShopInfo.objects.order_by(F('open_hour')*60*60 + F('open_min')*60) 14 15 # close_sec = close_hour_sec*60*60 + close_min_sec*60 16 # close_sec = models.ShopInfo.objects.order_by(F('close_hour')*60*60 + F('close_min')*60) 17 18 same_towns = models.ShopInfo.objects.filter(address__contains=towns[select_town]).all() #共通の町に所在する複数のデータを抽出 19 20 if request.method == 'GET': 21 template_name = "{}.html".format(select_town) 22 23 24 options = { 25 'info':info, 26 'same_towns':same_towns, 27 'now_sec':now_sec, 28 # 'open_sec':open_sec, 29 # 'close_sec':close_sec, 30 } 31 32 return render(request, template_name, {'options':options}) 33

最後にishikawa.html(例として石川町を検索した際に表示させるhtmlを記載)です。

python

1 {% if options.info.open_sec <= options.now_sec and options.now_sec < options.info.close_sec %} 2 {% for town in options.same_towns %} 3 <div> 4    営業時間:{{town.open_hour}}{{town.open_min}}分~{{town.close_hour}}{{town.close_min}}5 </div> 6 {% endfor %} 7 {% endif %}

ここで、if文を使って登録された営業時間の範囲内に現在時刻が含まれていたらその(現在営業中の)お店のみを表示させたいのですが、どうやらoptions.info.open_secとoptions.info.close_secがうまく出力されておらず結果が空白で出てきます。
DBではoptions.info.open_secとoptions.info.close_secはいずれもデフォルト値の0が出力されてしまいます。

if文を外すと石川町のお店はうまく出力されるのですが、それをどのようにすれば現在営業中のお店のデータのみを表示できるのかが分かりません。

とても無駄の多いソースコードかと思いますが、どなたかご教授お願い致します。

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

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

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

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

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

guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問