Отображение таблицы из базы данных с использованием Python, Flask, Sqlalchemy и HTML на pythonanywhere - PullRequest
0 голосов
/ 08 ноября 2019

Итак, я пытаюсь отобразить таблицу из моей базы данных в моем веб-приложении. однако, когда я запускаю программу, я получаю все свои данные в 1 строку, а не выстраиваюсь в соответствующие столбцы. Части моего HTML и Python кода приведены ниже. Я использую pythonanywhere для запуска моего веб-приложения. Любой совет, где я портлю?

ID.HTML

<table style="margin-left: 20px;">
<!-- Table headers -->
    <th>
         <tr style="color: black; ">

        <th>Last Name</th>
        <th>First Name</th>
        <th>SSN</th>
        <th>MRN</th>
        <th>Age</th>
        <th>Sex</th>
        <th>Incounter Type</th>
        <th>Provider Last Name</th>
        <th>Provider First Name</th>
        <th>Admin Date</th>
        <th>Admin Time</th>
        <th>Hospital</th>
        <th>Floor</th>
        <th>Room</th>
        <th>Bed</th>

        </tr>
    </th>

    <tr>
    {%for patient_id in query%}

    <td>
        {{patient_id.lname}}
     </td>
     <td>
        {{patient_id.fname}}
    </td>
    <td>
        {{patient_id.ssn}}
    </td>
    <td>
        {{patient_id.mrn}}
    </td>
    <td>
        {{patient_id.age}}
    </td>
    <td>
        {{patient_id.sex}}
    </td>
    <td>
        {{patient_id.incounter_type}}
    </td>
    <td>
        {{patient_id.provider_lname}}
    </td>
    <td>
        {{patient_id.provider_fname}}
    </td>
    <td>
        {{patient_id.admin_date}}
    </td>
    <td>
        {{patient_id.admin_time}}
    </td>
    <td>
        {{patient_id.location_hospital}}
    </td>
    <td>
        {{patient_id.location_floor}}
    </td>
    <td>
        {{patient_id.location_room}}
    </td>
    <td>
        {{patient_id.location_bed}}
    </td>
    {%endfor%}
    </tr>
 </table>

flask_app.py

class patient_ID(db.Model):

__tablename__ = "patient_ID"

incounter_types = [('inpatient', 'inpatient'),
               ('outpatient', 'outpatient')
               ]

lname = db.Column(db.String(128))
fname = db.Column(db.String(128))
ssn = db.Column(db.String(9))
mrn = db.Column(db.String(8),primary_key=True)
age = db.Column(db.String(3))
sex = db.Column(db.String(6))
incounter_type = db.Column(db.String(128))#, choices=incounter_types)
provider_lname = db.Column(db.String(128))
provider_fname = db.Column(db.String(128))
admin_date = db.Column(db.String(128))
admin_time = db.Column(db.String(128))
location_hospital = db.Column(db.String(128))
location_floor = db.Column(db.String(3))
location_room = db.Column(db.String(10))
location_bed = db.Column(db.String(1))


@app.route("/Patient_Info/", methods=["GET", "POST"])
@login_required
def patient_info_page():
     if request.method == "GET":
         return render_template("ID.html", query=patient_ID.query.all())

     if not current_user.is_authenticated:
         return redirect(url_for('index'))
     ID = patient_ID(mrn=request.form["mrns"])

     return redirect(url_for('patient_info_page'), query)

1 Ответ

1 голос
/ 08 ноября 2019

Вы хотите строку для каждого пациента, поэтому напишите:

{% for patient_id in query %}
<tr>
  <td>
    {{patient_id.lname}}
  </td>
...
</tr>
{% endfor %}
...