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

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

ただいまの
回答率

88.61%

Flaskからブラウザへ送信したjsonファイルを使ってHTMLを生成したい

解決済

回答 1

投稿

  • 評価
  • クリップ 0
  • VIEW 2,046

pigHuman

score 13

前提・実現したいこと

FlaskとMongoDBを使ってwebアプリを作ろうとしています。
特定URLからページを開いた際、アプリにログインしているユーザごとに用意されたテーブルの中身を自動的に検索し、結果をjsonファイルへ詰め込み、そのjsonファイルの中身の特定要素をHTML内の別々の箇所に表示させたいのですがうまく反映されませんでした。

ユーザー名: {{ username }}
パスワード: {{ password }}
個人メモ: {{ memo }}
のように表示させたいです

発生している問題・エラーメッセージ

JSONファイルを実際にHTML側へ渡すことには成功しましたが、中身を要素ごとに分けて扱うことができませんでした。
例えば"username"の中にある"test"という名前だけを抜き取って表示しようとすると、そもそも何も表示されず空白のままになってしまいます。

該当のソースコード

[{
    "username":"test"
    "password":"test"
    "memo":"hogehoge"
}]
@app.route("/test/",methods=['GET'])
def test():
    test_data = test_find()
    print(test_data)
    return render_template('test.html',test_data=test_data)

def test_find():
    username = session["username"]
    test_data = mongo.db.users.find_one({"username": username})
    del test_data["_id"]
    user_data = json.dumps(test_data)
    return test_data
<!DOCTYPE html>
<html lang="ja">
<head>
  <meta charset="utf-8">
  <title>test</title>
</head>
<body>
  <div>
    {% set name = test["username"] %}
    {% set pass = test["password"] %}
    {% set memo = test["memo"] %}

    <p>名前: {{ name }}</p>
    <p>パスワード: {{ pass }}</p>
    <p>個人メモ: {{ memo }}</p>
  </div>
</body>
</html>

試したこと

{% for test in test_data %}で要素を別々に扱おうとしましたが、一文字ずつに区切られて変数に入っていました。
その状態であれば一文字ずつではあるものの実際に画面に表示されましたが、要素ごとに別々の箇所での利用はできませんでした。

補足情報(FW/ツールのバージョンなど)

使用ツール
Flask,flask-session,MongoDB,pymongo,flask-pymongo

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 1

checkベストアンサー

+1

  • 提示されたjsonデータの辞書部分、カンマが含まれていないようですので、カンマで区切る必要があります。
  • test_find()の戻り値がJSON文字列であれば、json.loadsでデータ化する必要があります。
  • return render_template('test.html',test=test_data[0])ではないでしょうか?

以下当方での検証コードと結果です。テンプレートは提示HTMLをそのまま利用しています。

from flask import Flask, render_template
import json # 追加
app = Flask(__name__)

@app.route('/')
def hello_world():
    return "Hello World!"

@app.route("/test/",methods=['GET'])
def test():
    test_data = '[{"username":"test", "password":"test", "memo":"hogehoge"}]' # = test_find()
    print(test_data) # [{"username":"test", "password":"test", "memo":"hogehoge"}]
    test_data = json.loads(test_data) # json文字列をデータに変換
    print(test_data) # [{'password': 'test', 'username': 'test', 'memo': 'hogehoge'}]

    return render_template('test.html',test=test_data[0])

if __name__ == '__main__':
    app.run(debug=True)


イメージ説明

投稿

編集

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2018/12/22 13:09

    この方法を参考にしたところ無事動かすことができました!有難うございます!

    キャンセル

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

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

関連した質問

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