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

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

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

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

Python

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

Q&A

解決済

1回答

2561閲覧

DjangoのListViewで表示件数を自分で指定できるようにしたいです

Taka787

総合スコア23

Django

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

Python

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

0グッド

0クリップ

投稿2020/02/27 04:08

現在、DjangoのListViewで品目マスタ表みたいなものを表示していてデフォルトで1ページに100件表示するようにしています。表示件数をプルダウンで自分で指定できるようにしたいのですが以下のコードではうまくいきませんでした。
どなたかご教授いただけないでしょうか?

python

1view.py 2 3from django.views.generic import ListView, DetailView 4from insert_data.models import Item, Order 5 6class ItemMasterList(ListView): 7 """品目マスタ一覧""" 8 template_name = 'master_management/item_master_list.html' 9 context_object_name = 'item_master_list' 10 model = Item 11 paginate_by = 100 # 1ページあたり100件表示 12 ordering = ['item_code'] 13 14 def paginate(self): 15 paginate_by = self.request.GET.get('paginate_by') 16 17 return paginate_by 18 19 20 def get_context_data(self, **kwargs): 21 context = super().get_context_data(**kwargs) 22 context['title'] = context['page_header'] = "品目マスタ一覧" 23 24 return context 25 26 def get_queryset(self): 27 q_item_code = self.request.GET.get('item_code') 28 q_item_name = self.request.GET.get('item_name') 29 q_small_class_code = self.request.GET.get('small_class_code') 30 q_small_class_name = self.request.GET.get('small_class_name') 31 q_medium_class_code = self.request.GET.get('medium_class_code') 32 q_medium_class_name = self.request.GET.get('medium_class_name') 33 q_register_datetime_st = self.request.GET.get('register_datetime_st') 34 q_register_datetime_end = self.request.GET.get('register_datetime_end') 35 q_final_update_employee_code = self.request.GET.get('final_update_employee_code') 36 q_final_update_employee = self.request.GET.get('final_update_employee') 37 q_final_update_datetime_st = self.request.GET.get('final_update_datetime_st') 38 q_final_update_datetime_end = self.request.GET.get('final_update_datetime_end') 39 40 if q_register_datetime_st and q_register_datetime_end and q_final_update_datetime_st and q_final_update_datetime_end: 41 object_list = Item.objects.filter( 42 item_code__contains=q_item_code, item_name__contains=q_item_name, 43 small_class_code__contains=q_small_class_code, small_class_name__contains=q_small_class_name, 44 medium_class_code__contains=q_medium_class_code, medium_class_name__contains=q_medium_class_name, 45 register_datetime__gte=q_register_datetime_st, register_datetime__lte=q_register_datetime_end, 46 final_update_employee_code__contains=q_final_update_employee_code, 47 final_update_employee__contains=q_final_update_employee, 48 final_update_datetime__gte=q_final_update_datetime_st, final_update_datetime__lte=q_final_update_datetime_end 49 ).distinct() 50 else: 51 object_list = Item.objects.all() 52 return object_list

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

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

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

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

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

guest

回答1

0

ベストアンサー

get_paginate_byメソッドを上書きすれば実現できそうです。

これでどうでしょうか。

python

1def get_paginate_by(self, queryset): 2 # paginate_byパラメータがない場合はデフォルトでクラス変数で定義されている値を返す 3 return self.request.GET.get('paginate_by', ItemMasterList.paginate_by)

投稿2020/02/27 04:38

編集2020/02/27 05:43
mistn

総合スコア1191

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

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

Taka787

2020/02/27 05:20

早速ご回答ありがとうございます。 おっしゃる通りにやるとうまくいきました しかし、デフォルトでは100件表示にしておきたいのですが、paginate_by = 100 # 1ページあたり100件表示 を設定しても全件表示されてしまします。
mistn

2020/02/27 05:45

追記しました。 get()の第二引数に値を設定することでget()の返り値がNoneであった場合の値を決めることができます。 ただこの方法だと空白であった場合などには対応できません。
mistn

2020/02/27 05:48

それとpaginate_byが0以下である場合や文字列である場合の対応も必要ですね。
Taka787

2020/02/27 06:50

ありがとうございます。 解決できました。
Taka787

2020/02/27 06:51

def get_paginate_by(self, queryset): paginate_by = self.request.GET.get('paginate_by') if paginate_by: return paginate_by else: return 100 # デフォルトで1ページあたり100件表示
Taka787

2020/02/27 06:51

⬆︎でもできましたw
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問