前提・実現したいこと
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文を外すと石川町のお店はうまく出力されるのですが、それをどのようにすれば現在営業中のお店のデータのみを表示できるのかが分かりません。
とても無駄の多いソースコードかと思いますが、どなたかご教授お願い致します。
あなたの回答
tips
プレビュー