J'ai un code comme celui-ci pour récupérer les données de la base de données et je veux les afficher en html.
C'est app.py
@app.route('/news')
def news():
import pymysql
import re
Host='localhost'
user = 'root'
password = ''
db = 'skripsi'
try:
con = pymysql.connect(Host=host,user=user,password=password,db=db, use_unicode=True, charset='utf8')
print('+=========================+')
print('| CONNECTED TO DATABASE |')
print('+=========================+')
except Exception as e:
sys.exit('error',e)
cur = con.cursor()
cur.execute("SELECT * FROM dataset")
data = cur.fetchall()
for row in data:
id_berita = row[0]
judul = row[1]
isi = row[2]
print('===============================================')
print('BERITA KE', id_berita)
print('Judul :', judul)
print('Isi :', isi)
print('===============================================')
return render_template('home.html')
C'est le résultat
C'est berita.html . Je veux afficher à l'intérieur de div class = output
<body>
<center>
<header style="padding-top: 10px; font-family: Calibri; font-size: 40pt;">WELCOME!</header><br>
<div class="nav">
<a href="/home">Home
<a href="/berita">Berita
<a href="/preprocessing">Pre-Processing
<a href="/feature">Fitur Ekstraksi
<a href="/knn">KNN
</div>
<div class="output">
</div>
Vous pouvez transmettre vos données en utilisant render_template()
comme ceci:
cur = con.cursor()
cur.execute("SELECT * FROM dataset")
data = cur.fetchall()
render_template('template.html', data=data)
Ensuite, dans votre modèle, parcourez les lignes, par exemple, vous pouvez rendre les lignes du tableau pour chaque ligne:
{% for item in data %}
<tr>
<td>{{item[0]}}</td>
<td>{{item[1]}}</td>
...
</tr>
{% endfor %}
render_template vous permet de passer des variables en html, et jinja2 vous aide à le manipuler. Il vous suffit de formater le résultat de votre requête et de l'envoyer dans render_template
@app.route('/test')
def test_route():
user_details = {
'name': 'John',
'email': '[email protected]'
}
return render_template('test.html', user=user_details)
<!DOCTYPE html>
<html>
<head>
<title>test</title>
</head>
<body>
<!-- use {{}} to access the render_template vars-->
<p>{{user.name}}</p>
<p>{{user.email}}</p>
</body>
</html>
pour tirer le meilleur parti de jinja2, jetez un oeil à son Documentation
id | nom | email | téléphone | 1 | Eltac | [email protected] | +99421112 |
Vous pouvez faire quelque chose comme ça:
app_name.py
from flask import Flask, render_template
import mysql.connector
mydatabase = mysql.connector.connect(
Host = 'localhost(or any other Host)', user = 'name_of_user',
passwd = 'db_password', database = 'database_name')
mycursor = mydatabase.cursor()
#There you can add home page and others. It is completely depends on you
@app.route('/example.html')
def example():
mycursor.execute('SELECT * FROM user_info')
data = mycursor.fetchall()
return render_template('example.html', output_data = data)
Dans le code ci-dessus, nous utilisons la méthode fetchall (), c'est pourquoi l'ID est également inclus automatiquement
(La balise html de l'en-tête et d'autres sont ignorées. J'écris uniquement à l'intérieur du corps) example.html
--snip--
<table>
<thead>
<tr>
<th>ID</th>
<th>Name</th>
<th>Email</th>
<th>Phone</th>
</tr>
</thead>
<tbody>
{% for row in output_data %} <-- Using these '{%' and '%}' we can write our python code -->
<tr>
<td>{{row[0]}}</td>
<td>{{row[1]}}</td>
<td>{{row[2]}}</td>
<td>{{row[3]}}</td>
</tr>
{% endfor %} <-- Because it is flask framework there would be other keywords like 'endfor' -->
</tbody>
</table>
--snip--
Et enfin vous obtenez le résultat attendu