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

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

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

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

Python

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

Q&A

解決済

1回答

2010閲覧

モデルの属性にアクセスする書き方なのか

退会済みユーザー

退会済みユーザー

総合スコア0

Django

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

Python

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

0グッド

0クリップ

投稿2017/08/31 13:29

Djangoチュートリアルチュートリアルを見ながらwebサイトを作っています。
index.htmlに

{% extends "polls/base.html" %} {% load staticfiles %} {% block contents %} <table border="1" class="table table-striped"> <tr> <th>質問内容</th> <th>公開日</th> <th></th> </tr> {% for question in questions %} <tr> <td>{{ question.question_text }}</td> <td>{{ question.pub_date }}</td> <td><a href="{% url 'polls:polls_detail' question.pk %}">詳細画面へ</a></td> </tr> {% endfor %} </table> {% endblock contents %}

とあり、
models.pyに

import datetime from django.db import models from django.utils import timezone # Create your models here. class Question(models.Model): class Meta: verbose_name = '質問' verbose_name_plural = '質問の複数形' ordering = ['-pub_date'] question_text = models.CharField(max_length=200,default='xxxx') pub_date = models.DateTimeField('date published', default=timezone.now) def __str__(self): return self.question_text def was_published_recently(self): return self.pub_date >= timezone.now() - datetime.timedelta(days=1) was_published_recently.admin_order_field = 'pub_date' was_published_recently.boolean = True was_published_recently.short_description = 'Published recently?' class Choice(models.Model): def __str__(self): return self.choice_text question = models.ForeignKey(Question,on_delete=models.CASCADE) # question = models.ForeignKey('polls.Question',on_delete=models.CASCADE) choice_text = models.CharField(max_length=200) votes = models.IntegerField(default=0)

とありました。

{{ question.question_text }}

{{ question.pub_date }}

のquestion_text・pub_dateはmodels.pyの

question_text = models.CharField(max_length=200,default='xxxx') pub_date = models.DateTimeField('date published', default=timezone.now)

なのでしょうか?

{% for question in questions %}

はモデルにあるquestionsデータを一つずつ取り出しそれをquestionに格納し、
さらにmodels.pyのquestion_text・pub_dateにアクセスしているということなのでしょうか?

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

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

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

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

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

guest

回答1

0

ベストアンサー

modelsのQuestionにはたくさんデータが入っていて、

html

1{% for question in questions %}

はその中からviewの

python

1.order_by('ならびじゅん')

ならびじゅんの並べ方で最初から1つずつデータを取り出して、そのデータの中のquestion_textと
pub_dateを表示させるということです。
例えば、

python

1#models.py 2 3class Disc(models.Model): 4 name = models.CharField('CD,DVDの名前',max_length=255) 5 genres = models.IntegerField('ジャンル',choices=JANRU_D,default=8) 6 7#forms.py 8 9class DiscForm(ModelForm): 10 class Meta: 11 model = Disc 12 fields = ('name','genres') 13 14#views.py 15def disc_list(request): 16 disc = Disc.objects.all().order_by('name')#<---この場合は名前の降順 17 #disc = Disc.objects.all().order_by('-name')<--名前の昇順 18 return render(request,'homebook/disc_list.html',{'disc' : disc})

という感じです。

投稿2017/08/31 13:57

sizumita

総合スコア196

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問