Как правильно отображать результаты запроса SQLalchemy в шаблонах Flask Jinja - PullRequest
0 голосов
/ 21 ноября 2018

У меня проблемы с отображением результатов запроса SQLAlchemy на странице шаблона Jinja.

Я основываю свой проект на драйверах Формулы 1 и командах, для которых они управляют.У меня есть страница со списком команд в Формуле-1, на которой должны быть перечислены гонщики, участвующие в гонках для каждой отдельной команды (отношение «многие ко многим» между классами пилотов и команд).

Вывод, который я получаю, является правильным, однакоПохоже, он сгруппирован в вывод типа спискаЯ бы хотел, чтобы драйверы для каждой команды были указаны независимо друг от друга как строки, а не как список, сгруппированный вместе.

Вот мой код:

models.py

from datetime import datetime
from app import db


class Team_driver(db.Model):
    # Many-to-many relationship table between Driver and Team
    __tablename__ = "team_driver"
    id = db.Column(db.Integer, primary_key=True)
    team_id = db.Column(db.Integer, db.ForeignKey('team.id'), nullable=False)
    driver_id = db.Column(db.Integer, db.ForeignKey('driver.id'), nullable=False)


class Team(db.Model):
    __tablename__ = "team"
    id = db.Column(db.Integer, primary_key=True)
    teamName = db.Column(db.String(64))
    nationality = db.Column(db.String(64))
    # relationship between Team table and Driver table, reference 'team' in forms
    drivers = db.relationship('Driver', secondary="team_driver", backref='team')

    def __repr__(self):
        # specify variables to return to web page from backref
        return '{}'.format(self.teamName)


class Driver(db.Model):
    __tablename__ = "driver"
    id = db.Column(db.Integer, primary_key=True)
    firstName = db.Column(db.String(64))
    lastName = db.Column(db.String(64))
    raceNum = db.Column(db.Integer)
    nationality = db.Column(db.String(64))
    # relationship between Driver table and Team table, reference 'driver' in forms
    teams = db.relationship('Team', secondary="team_driver", backref='driver')

    def __repr__(self):
        # specify variables to return to web page from backref
        return '{} {}'.format(self.firstName,self.lastName)

route.py (только для определенного маршрута)

@app.route('/teamDetails', methods=['GET', 'POST'])
def teamDetails():
    details = Team.query.all()
    return render_template('teamDetails.html',  title='Team Details', details=details)

driverDetails.html

<!-- teamDetails.html -->

<!-- all other html files must now extend index.html and not base.html -->
{% extends "index.html" %}

{% block content %}
    <h1>Team Details</h1>
    {% for d in details %}
    <div><p>Team Name: {{ d.teamName }}<br>Nationality: {{ d.nationality }}
    <br>Drivers: {{ d.driver }}</p></div>
    {% endfor %}
{% endblock %}

Вот вывод, полученный с веб-страницы

снимок экрана свывод веб-страницы

Мне нужна страница для отображения соответствующих драйверов, но отдельно, без скобок [].

Может кто-нибудь помочь с ошибками?

Большое спасибо.

1 Ответ

0 голосов
/ 21 ноября 2018

Поскольку d.driver - это список драйверов, вы должны печатать каждый элемент списка отдельно, потому что если вы печатаете список чего-либо, он также будет содержать скобки.

{% block content %}
<h1>Team Details</h1>
{% for d in details %}
  <div><p>Team Name: {{ d.teamName }}<br>Nationality: {{ d.nationality }}
  <br>Drivers: 
  {% for driver in d.drivers %}
    {{ driver }} 
  {% endfor %}
  </p></div>
{% endfor %}
{% endblock %}
...