Flask:如何清晰地显示数据库中的数据

2024-04-23 07:07:36 发布

您现在位置:Python中文网/ 问答频道 /正文

我使用Flask和Firebase作为数据库

我想展示数据库中的7个变量,我制作了它,但不是我想要的方式

当我从数据库获取数据时,我的屏幕如下所示:

enter image description here

我试着这样表现: enter image description here 没有{}我的代码是:这是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条回答
网友
1楼 · 发布于 2024-04-23 07:07:36

您可以使用for-loop、f-stringjoin()将代码中的每一行转换为字符串

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中使用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)

相关问题 更多 >