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

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

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

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

Python

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

Q&A

解決済

2回答

2676閲覧

Djangoでのテーブルの並び替えと分割

ROCKKBOY

総合スコア7

Django

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

Python

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

0グッド

0クリップ

投稿2021/08/10 13:22

編集2021/08/10 13:46

#困っているところ
Djangoを使ったアプリ開発に挑戦しているのですが、テーブルの並び替えと分割の仕方がわからず思うようにできません。ひとまず、簡単な例に置き換えて挑戦しています。以下の問題でわかる方がいらっしゃればご教授いただければ幸いです。

#環境
python 3.9.5
Django 3.2.4

#モデル
アプリが以下の二つのテーブルを有するとします。

django

1#=================================================================== 2#models.py 3#=================================================================== 4from django.db import models 5 6# Create your models here. 7 8List = (('Male','男'),('Female','女')) 9 10class ClassModel (models.Model): 11 ClassNumber = models.IntegerField() 12 HomeroomTeacher = models.CharField(max_length=20) 13 14class MenberModel (models.Model): 15 BelongClass = models.ForeignKey(ClassModel,on_delete=models.CASCADE) 16 ForM = models.CharField(choices=List,max_length= 6,default='Male') 17 Number = models.IntegerField() 18 Name = models.CharField(max_length=20) 19 Point = models.IntegerField()

・クラステーブル

クラス担任
1I先生
2J先生

・クラスメンバーテーブル

クラス出席番号性別名前点数
13Cくん100
22ロくん80
15Eさん60
14Dさん60
12Bくん45
23ハくん60
11Aくん60
24二さん40
25ホさん60
16Fさん90
21イくん55
26へさん70

これ以下のように4つの表へ整理し、表示させることが目標です。

クラス担任出席番号性別名前点数
1I先生1Aくん60
1I先生2Bくん45
1I先生3Cくん100
平均68.3333
クラス担任出席番号性別名前点数
1I先生4Dさん60
1I先生5Eさん60
1I先生6Fさん90
平均70
クラス担任出席番号性別名前点数
2J先生1イくん55
2J先生2ロくん80
2J先生3ハくん60
平均65
クラス担任出席番号性別名前点数
2J先生4二さん40
2J先生5ホさん60
2J先生6へさん70
平均56.6667

#試したこと
以下のように、#1の個所で、「order_by」を使って並び替えをしてみました。うまくいっているように見えたのですがこれでは、「ClassModel」のidで並び替えられただけで、ClassModelのClassNumberでは並び変わりませんでした。

django

1#=================================================================== 2#views.py 3#=================================================================== 4from django.shortcuts import render 5from .models import ClassModel,MenberModel 6 7def tabletest(request): 8 object_list = MenberModel.objects.order_by('BelongClass','Number') #1 9 object_list2 = ClassModel.objects.all 10 return render(request, 'testapp2.html',{'object_list':object_list}) 11

html

1 2<table border = '1'> 3<tr> 4 <th>クラス</th> 5 <th>担任</th> 6 <th>出席番号</th> 7 <th>性別</th> 8 <th>名前</th> 9 <th>点数</th> 10</tr> 11 12{% for Object in object_list %} 13 <tr> 14 <td>{{Object.BelongClass.ClassNumber}}</td> 15 <td>{{Object.BelongClass.HomeroomTeacher}}</td> 16 <td>{{Object.Number}}</td> 17 <td>{{Object.get_ForM_display}}</td> 18 <td>{{Object.Name}}</td> 19 <td>{{Object.Point}}</td> 20 </tr> 21{% endfor %} 22 23</table>

結果

クラス担任出席番号性別名前点数
1I先生1Aくん60
1I先生2Bくん45
1I先生3Cくん100
1I先生4Dさん60
1I先生5Eさん60
1I先生6Fさん90
2J先生1イくん55
2J先生2ロくん80
2J先生3ハくん60
2J先生4二さん40
2J先生5ホさん60
2J先生6へさん70

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

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

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

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

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

guest

回答2

0

ベストアンサー

関連モデルのフィールド名で並び替えの場合は以下のようにアンスコを2つで指定できます

python

1object_list = MenberModel.objects.filter.order_by.('BelongClass__ClassNumber','Number')

分割したいのであれば以下のように条件をしていしてグループごと取得するのが良いかと思います

python

1object_list = MenberModel.objects.filter(ForM='Male',BelongClass__ClassNumber=1).order_by.('Number') #1

投稿2021/08/10 15:19

holy_

総合スコア364

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

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

ROCKKBOY

2021/08/11 03:55

早速の回答ありがとうございます。 アンダーバー二つだったのですね、ここがわからず苦労していました。大変助かりました。 分割に関してはご教授いただいた方法で確かに達成できます。しかしこのやり方ですと、クラスが増えればその分リストを定義しなければなりません。 クラスが100だろうが200だろうが、対応できるような方法はないのでしょうか?
ROCKKBOY

2021/08/12 13:48

クラスと性別で二つの要素で分割したいと思っているので、教えていただいたregroupだけですと、うまく処理できませんでした。regroupでネストにできたりするといいのですが、うまくいきません。そこでifchangedというタグを併用したところ、うまく分割することができました。 テンプレート側で処理というヒントを受けて調べてみましたが、テンプレートタグだけでもかなり数があるのですね。とても勉強になります。 まだまだ改良の余地が多いのですが、ひとまずこの質問は解決とさせていただきます。 holy_ さんの意見はとても助けになりましたのでベストアンサーに選ばせていただきます。 ありがとうございました。 ======================= {% regroup object_list by BelongClass as object_list_2 %} {% for object in object_list_2%} {% for Object in object.list %} {% ifchanged Object.ForM %} </table> <table border = '1'> <tr> <th>クラス</th> <th>担任</th> <th>出席番号</th> <th>性別</th> <th>名前</th> <th>点数</th> </tr> <tr> <td>{{Object.BelongClass.ClassNumber}}</td> <td>{{Object.BelongClass.HomeroomTeacher}}</td> <td>{{Object.Number}}</td> <td>{{Object.get_ForM_display}}</td> <td>{{Object.Name}}</td> <td>{{Object.Point}}</td> </tr> {% else %} <tr> <td>{{Object.BelongClass.ClassNumber}}</td> <td>{{Object.BelongClass.HomeroomTeacher}}</td> <td>{{Object.Number}}</td> <td>{{Object.get_ForM_display}}</td> <td>{{Object.Name}}</td> <td>{{Object.Point}}</td> </tr> {% endifchanged %} {% endfor %} </table> {% endfor %} ====================================
guest

0

ほかの解決策を見つけたので備忘録のために投稿

python

1#views.py 2 3from django.shortcuts import render 4from .models import MenberModel 5from django.db.models import Avg 6 7# Create your views here. 8 9def tabletest(request): 10 11 Que_List = [] 12 13 ForMs = list(MenberModel.objects.all().values('ForM').distinct()) 14 Classes = list(MenberModel.objects.all().values('BelongClass__ClassNumber').distinct()) 15 16 NewForMs = [] 17 NewClasses = [] 18 19 for temp in ForMs: 20 NewForMs.append(temp['ForM']) 21 for temp in Classes: 22 NewClasses.append(temp['BelongClass__ClassNumber']) 23 24 for FM in NewForMs: 25 for Class in NewClasses: 26 Que_temp = MenberModel.objects.filter(ForM= FM,BelongClass__ClassNumber=Class).order_by('Number') 27 Ave_temp = Que_temp.aggregate(Avg('Point')) 28 if not Ave_temp['Point__avg'] is None: 29 Que_List.append({'Que':Que_temp,'Ave':Ave_temp}) 30 31 return render(request, 'testapp2_2.html',{'Que_List':Que_List})

html

1testapp2_2.html 2{% for Query in Que_List %} 3 <table border = '1'> 4 <tr> 5 <th>クラス</th> 6 <th>担任</th> 7 <th>出席番号</th> 8 <th>性別</th> 9 <th>名前</th> 10 <th>点数</th> 11 </tr> 12 13 {% for Object in Query.Que%} 14 <tr> 15 <td>{{Object.BelongClass.ClassNumber}}</td> 16 <td>{{Object.BelongClass.HomeroomTeacher}}</td> 17 <td>{{Object.Number}}</td> 18 <td>{{Object.get_ForM_display}}</td> 19 <td>{{Object.Name}}</td> 20 <td>{{Object.Point}}</td> 21 </tr> 22 {% endfor %} 23 <td colspan="5">平均</td> 24 <td>{{Query.Ave.Point__avg}}</td> 25 </table> 26 27{% endfor %} 28

投稿2021/08/15 00:47

編集2021/08/15 10:36
ROCKKBOY

総合スコア7

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問