Flask: Как четко отображать данные из базы данных

#python #flask #jinja2

#питон #flask #jinja2

Вопрос:

Я использую Flask и Firebase для базы данных.

Я хочу показать 7 переменных из базы данных, и я сделал это, но не так, как я хотел.

Когда я получаю данные из базы данных, мой экран выглядит так :

введите описание изображения здесь

Я пытаюсь показать это так: введите описание изображения здесьбез ‘ { } ‘ Вот мой код: это routes.py

 @app.route('/satis', methods=['GET', 'POST'])
def satis():
    if (request.method == 'POST'):
        sehir=request.form['il']
        yas=request.form['yas']
        id=request.form['id']
        kat=request.form['kategori']
        gun=request.form['satisgunu']
        cins=request.form['cinsiyet']
        tarz=request.form['satistarzi']
        db = firebase.database()
        db.child("names").push({"sehir": sehir,"yas":yas,"id":id,"kat":kat,"gun":gun,"cins":cins,"tarz":tarz})
        todo = db.child("names").get()
        to = todo.val()
        return render_template('satis.html', t=to.values())
    return render_template('satis.html')
 

Это satis.html

 <div class="container-fluid">
        {% for l in t %}
            <ul class="list-group">
                <li class="list-group-item">
                    <h4>{{l}}</h4>
                </li>
            </ul>
        {% endfor %}
    </div>
{% endblock %}
 

Комментарии:

1. может быть, лучше отправить его как словарь — без использования .values() — и последующего использования {% for key, val in t.items() %} {{key}}:{{val}} {% endfor %} — ему нужно будет только добавлять , между элементами (но не после последнего элемента — вероятно, с for.last или чем-то подобным). ИЛИ, если вам это нужно как отдельная строка в tempalte, тогда, возможно, отформатируйте ее в одну строку перед отправкой в шаблон

Ответ №1:

Вы можете преобразовать каждую строку в строку в коде, используя for -loop , f-string и join()

 data = [
    {'cins': 'kadin', 'gun': 'carsambra', 'id': '1', 'kat': 'cantra', 'sehir': 'izmir', 'tarz': '7', 'yas': '22'},
    {'cins': 'kadin', 'gun': 'pazartesi', 'id': '1', 'kat': 'cantra', 'sehir': 'ankara', 'tarz': '5', 'yas': '18'},
]

new_data = []

for row in data:
    text = ', '.join(f'{key}:{val}' for key, val in row.items())
    new_data.append(text)
    print(text)
 

Результат

 cins:kadin, gun:carsambra, id:1, kat:cantra, sehir:izmir, tarz:7, yas:22
cins:kadin, gun:pazartesi, id:1, kat:cantra, sehir:ankara, tarz:5, yas:18
 

и теперь вы можете отправлять new data в шаблон.


Или вы можете попытаться сделать то же template самое, используя also for -loop, row.items() с key,val а также loo.last пропустить , после последнего элемента

 from flask import Flask, render_template_string

app = Flask(__name__)

@app.route('/')
def inder():

    data = [
        {'cins': 'kadin', 'gun': 'carsambra', 'id': '1', 'kat': 'cantra', 'sehir': 'izmir', 'tarz': '7', 'yas': '22'},
        {'cins': 'kadin', 'gun': 'pazartesi', 'id': '1', 'kat': 'cantra', 'sehir': 'ankara', 'tarz': '5', 'yas': '18'},
    ]

    return render_template_string("""
    {% for row in data %}
        <ul class="list-group">
            <li class="list-group-item">
                <h4>{% for key, val in row.items() %}{{key}}:{{val}}{{ ", " if not loop.last }}{% endfor %}</h4>
            </li>
        </ul>
    {% endfor %}
    """, data=data)

app.run(debug=True)