#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)