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

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

ただいまの
回答率

91.02%

  • Python

    5498questions

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

  • Django

    758questions

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

過去のデータを古いもの順に5件まで表示させたい

解決済

回答 1

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 154
退会済みユーザー

退会済みユーザー

過去のデータを古いもの順に5件まで表示させたいです。過去のテストの受験日とスコアを表示させるプログラムを書いています。views.pyに

@login_required
def past_result(request):
    return render(request, 'past_result.html', {'chart': _view_plot(request)})

def _view_plot(request):
    results = TestAndUser.objects.filter(user=request.user).order_by('-date')
    scores = [1, 2, 3, 4, 5]
    dates = [results[4].date, results[3].date, results[2].date, results[1].date, results[0].date]
    heights = [results[4].score,results[3].score,results[2].score, results[1].score,results[0].score]
    image_data =[]
    for i in range(len(scores)):
        if scores[i] != None :
            image_data.append(scores[i])
            image_data.append(dates[i])
            image_data.append(heights[i])

    image_scores =[]
    image_dates = []
    image_heights = []
    for j in range(0,len(image_data),3):
        image_scores.append(image_data[j])
        image_dates.append(image_data[j+1])
        image_heights.append(image_data[j+2])


    plt.plot(image_scores, image_heights)
    plt.xticks(image_scores, image_dates)
    plt.fill_between(x=np.arange(1, 5, 0.01), y1=60, y2=100, facecolor='yellow', alpha=0.2)
    jpg_image_buffer = cStringIO.StringIO()
    plt.savefig(jpg_image_buffer)

    array = base64.b64encode(jpg_image_buffer.getvalue())
    jpg_image_buffer.close()
    return array


とコードを書きました。
models.pyには

class TestAndUser(models.Model):
    dates = models.ImageField(upload_to='images', null=True, blank=True,)

    score = models.IntegerField(max_length=100,null=True)


とコードを書きました。
最終的には過去のテストの受験日とスコアを画像として表示させたいです。しかし、今のコードでは5つデータが入っているならエラーは出ないのですが、4つなど5つ未満の場合list index out of range とエラーが出ます。エラーが出る原因はわかっていて、results[4]などがないからだと思っています。
models.pyのdatesには20170809(2017年8月9日の意味)や20161203などが入っていて

results = TestAndUser.objects.filter(user=request.user).order_by('-date')


で、これを最新順に並べています。例えば、3件しかデータがない時

dates = [results[4].date, results[3].date, results[2].date, results[1].date, results[0].date]
    heights = [results[4].score,results[3].score,results[2].score, results[1].score,results[0].score]


の部分には3つずつ古いもの順にデータが入るようにしたいです。どのようにコードを書けば期待通りのプログラムが作れますか?
現在コードは

@login_required
def past_result(request):
    return render(request, 'past_result.html', {'chart': _view_plot(request)})

def _view_plot(request):
  results = TestAndUser.objects.filter(user=request.user).order_by('-date')

  print(results)
    dates = [r.consultation_date for r in reversed(tcresults)]
    heights = [r.tc for r in reversed(tcresults)]
    scores = [i + 1 for i in range(len(heights))]
    if len(scores) > 5:
        dates = dates[:5]
        heights = heights[:5]
        scores = scores[:5]

    image_data =[]
    for i in range(len(scores)):
        if scores[i] != None :
            image_data.append(scores[i])
            image_data.append(dates[i])
            image_data.append(heights[i])

    image_scores =[]
    image_dates = []
    image_heights = []
    for j in range(0,len(image_data),3):
        image_scores.append(image_data[j])
        image_dates.append(image_data[j+1])
        image_heights.append(image_data[j+2])


    plt.plot(image_scores, image_heights)
    plt.xticks(image_scores, image_dates)
    plt.fill_between(x=np.arange(1, 5, 0.01), y1=60, y2=100, facecolor='yellow', alpha=0.2)
    jpg_image_buffer = cStringIO.StringIO()
    plt.savefig(jpg_image_buffer)

    array = base64.b64encode(jpg_image_buffer.getvalue())
    jpg_image_buffer.close()
    return array


と書きました。
print(results)ではdateの新しいもの順に<QuerySet [<TestAndUser: xxx 59>, <TestAndUser: xxx 58>, <TestAndUser: xxx 54>, <TestAndUser: xxx 52>, <TestAndUser: xxx 50>, <TestAndUser: kadena xxx>]> と表示されました。

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 1

checkベストアンサー

+1

最大5要素を抽出する例です。基本的な考えとしては

  • 必要なリストはforループで作成
  • 5件を超えたら先頭の5件だけ抽出

です。

dates = [ r.date for r in reversed(results)]
heights = [ r.score for r in reversed(results)]
scores = [i+1 for i in range(len(heights))]
if len(scores) > 5:
    dates = dates[:5]
    heights = heights[:5]
    scores = scores[:5]

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2017/11/04 17:55

    ありがとうございます。そのようにコードを書いて、6件データを入れた時古いものから5件しかデータが取得できませんでした。なぜそのようになってしまったのでしょうか?質問文に現在のコードを記載しました。

    キャンセル

  • 2017/11/04 18:00

    データの取得部分(TestAndUser.objects.filter(user=request.user).order_by('-date')?)がどのように動いているかは私には分かりません。
    「5件まで表示させたい」のですから「5件を超えたら先頭の5件だけ抽出」するためのコードを回答しています。

    キャンセル

  • 2017/11/04 18:13 編集

    5件を超えたら先頭の5件だけ抽出するためのコードだと私も思うのですが、最も新しいものが取得できないという状況です。質問文に追加しました。

    キャンセル

  • 2017/11/04 19:16

    末尾から5個抽出しているだけなのですが、それがなぜ/どのように意図しない結果なのかは私には分かりません。新しい・古いというのもよく分かりません。

    キャンセル

  • 2017/11/04 23:23

    models.pyのdatesには20170809(2017年8月9日の意味)や20161203などが入っていて、この場合だと当たり前ですが、20170809の方が新しいデータだと考えます。

    キャンセル

  • 2017/11/04 23:28

    results = TestAndUser.objects.filter(user=request.user).order_by('-date') の部分では新しいもの順にデータが取れでいるのですが、
    dates = [ r.date for r in reversed(results)]
    heights = [ r.score for r in reversed(results)]
    scores = [i+1 for i in range(len(heights))]
    の部分ではデータが新しいデータ順など関係なくリストに格納されています。なのでおそらく上の3つの部分で期待した結果ではない結果を得ているのだと思います

    キャンセル

  • 2017/11/04 23:29

    if len(scores) > 5:
    dates = dates[:-5]
    heights = heights[:-5]
    scores = scores[:-5]
    と書くことで期待した結果を(新しいもの順に5件)得られました。もっといいやり方があれば教えてください。

    キャンセル

  • 2017/11/04 23:29

    「20170809の方が新しいデータだと考えます。」についてですが、データ取得の結果として返されたresultsの並びが何をもって正しいかは、私には判断できません。データ取得部分に誤りがあるのでは?

    キャンセル

  • 2017/11/04 23:31

    なぜ「[:-5]」と書くことで期待した結果が得られたのでしょうか?説明ください。

    キャンセル

  • 2017/11/04 23:36

    そもそも質問文では「過去のデータを古いもの順に5件まで表示させたい」とあるのですが、コメントでは「期待した結果を(新しいもの順に5件)」とあります。矛盾してませんか?

    キャンセル

  • 2017/11/04 23:52

    なぜデータ取得部分に誤りがあると考えましたか?

    キャンセル

  • 2017/11/04 23:52

    [:-5]は末尾の5件を取得できるからです

    キャンセル

  • 2017/11/04 23:54

    過去のデータを古いもの順に5件まで表示させたいは、最新の5件までのデータを取得してきて、そのデータを古いもの順に並べたい、の意です

    キャンセル

  • 2017/11/05 00:20

    それは「dates = [results[4].date, results[3].date, ~」とは異なるのですか?

    キャンセル

  • 2017/11/05 00:22

    >なぜデータ取得部分に誤りがあると考えましたか?
    あなたの意図しない結果になっているからではありませんか?私には分かりませんが。

    キャンセル

  • 2017/11/05 00:24

    >そもそも質問文では「過去のデータを古いもの順に5件まで表示させたい」とあるのですが、コメントでは「期待した結果を(新しいもの順に5件)」とあります。矛盾してませんか?
    これに対する回答をください。

    キャンセル

  • 2017/11/05 10:17

    過去のデータを古いもの順に5件まで表示させたいは、最新の5件までのデータを取得してきて、そのデータを古いもの順に並べたい、が回答なのですが伝わってませんか?それで言葉足らずなのですが「過去のデータを古いもの順に5件まで表示させたい」と書きました

    キャンセル

  • 2017/11/05 12:39

    質問文では「最新の5件までのデータを取得してきて」とあり、データが6件以上くる可能性については一切触れられていません。
    ですが、このコメントの最初に「6件データを入れた時」とおっしゃっています。
    データ取得部分では最大でも5件しかとれないのではないのでしょうか?ですからデータ取得部分がおかしいのでは?と問うています。
    繰り返しになりますが、私には取得されたリストが新しい・古いという順序は分かりません。

    キャンセル

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

  • ただいまの回答率 91.02%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る

  • Python

    5498questions

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

  • Django

    758questions

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