Django(Python)で、WEBアプリを作成しています。
下記のようなデータを表示したいです。
上記の表は、category、item共にそれぞれのid順に並んでいる状態です。
この通りに、id順に表示したいのですが、現状、categoryのidを無視した形で表示されてしまいます。
データベースには事前にデータを登録してあります。
categoryテーブルには、
id name
100 A
200 B
300 C
itemテーブルには、
id category item
101 A あ
102 A い
・・・
303 C こ
といった形で登録してあります。
なお、上記のモデルは、下記のようにしています。
python
1#model.py 2#categoryを扱うモデル 3class Category(models.Model): 4 id = models.IntegerField(primary_key=True) 5 name = models.CharField(max_length=20) 6'']]]
ここまでは、問題無いと思います。
そして、これを表示するために考えたコードが下記のものです。
やろうとしたことは、
displayList = [['A',['あ','い','う'],['B',['え','お','か','き']],['C',['く','け','こ']]]
というリストを作らせて、
テンプレート上で、forループを使ってデータを取り出して並べようというものです。
テンプレート上の処理自体はうまくいったので、上記のdisplayListを作る所だけ、質問させていただきたいと思います。
python
1#views.py 2def index(request): 3 category = Category.objects.all() #categoryデータを全部引っ張ってくる 4 categoryList = sorted([t for t in category], key=id) #categoryをid順に並べたリスト 5 item = Item.objects.all() #itemデータを全部引っ張ってくる 6 itemList = sorted([t for t in item], key=id) #itemをid順に並べたリスト 7 8 displayList = [] #表示用に作成したリスト 9 for c in category: 10 cList = [c] #ここで、['A']というリストが作成される 11 iList = [] #各categoryに属するitemを入れるための空リスト 12 for i in item: 13 if i.category == c: 14 iList.append(i) #ここで、['あ','い','う']というリストが作成される 15 sorted(iList, key=id) #iListをid順に並べる。 16 cList.append(iList) #ここで、['A',['あ','い','う']]というリストが作成される 17 displayList.append(cList) #ここで、[['A',['あ','い','う']]]というリストが作成される
上記の処理により、実際にdisplayListは作成されました。
しかし、ある時は、
displayList = [['C',['く','け','こ']],['A',['あ','い','う'],['B',['え','お','か','き']]]
となったり、
displayList = [['B',['え','お','か','き']],['C',['く','け','こ']],['A',['あ','い','う']]
となったり、categoryの順番がid通りになりません。各category内のitemの順番はid通りになっています。
displayListをsortedで並び替えられれば良いのですが、
categoryのidは、一つ深い内部のリストの中にあるのでkey=idではアクセスできず、困っています。
分かりづらい表現ですが、リスト内にある別のリスト内の要素のidに従って、外側のリストの並び替えをするにはどうしたらよいでしょうか?
つまり、上記の例で言えば、AやBやCのid順で並び替えたいということです。
どうしたらよいか、お分かりの方、ご教示いただければ幸いです。
よろしくお願いいたします。
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。