Primeiro commit do CRUD

parents
from flask import Flask, render_template, request, redirect, url_for
from flask_sqlalchemy import SQLAlchemy
from sqlalchemy import inspect, text
import os
app = Flask(__name__)
# Caminho do banco de dados
basedir = os.path.abspath(os.path.dirname(__file__))
app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:///' + os.path.join(basedir, 'database.db')
db = SQLAlchemy(app)
# Modelo da Tabela
class Pessoa(db.Model):
id = db.Column(db.Integer, primary_key=True)
nome = db.Column(db.String(100))
sexo = db.Column(db.String(20))
data_nascimento = db.Column(db.String(20))
cidade = db.Column(db.String(100))
telefone = db.Column(db.String(20))
def garantir_coluna_telefone():
db.create_all()
inspector = inspect(db.engine)
colunas = {coluna['name'] for coluna in inspector.get_columns('pessoa')}
if 'telefone' not in colunas:
with db.engine.begin() as conexao:
conexao.execute(text("ALTER TABLE pessoa ADD COLUMN telefone VARCHAR(20)"))
@app.route('/')
def index():
pessoas = Pessoa.query.all()
return render_template('index.html', pessoas=pessoas)
@app.route('/cadastro', methods=['GET', 'POST'])
def cadastro():
if request.method == 'POST':
nova = Pessoa(
nome=request.form['nome'],
sexo=request.form['sexo'],
data_nascimento=request.form['data_nascimento'],
cidade=request.form['cidade'],
telefone=request.form.get('telefone', '')
)
db.session.add(nova)
db.session.commit()
return redirect(url_for('index'))
return render_template('cadastro.html')
with app.app_context():
garantir_coluna_telefone()
if __name__ == '__main__':
app.run(debug=True)
File added
blinker==1.9.0
click==8.3.1
colorama==0.4.6
Flask==3.1.3
Flask-SQLAlchemy==3.1.1
greenlet==3.3.2
itsdangerous==2.2.0
Jinja2==3.1.6
MarkupSafe==3.0.3
SQLAlchemy==2.0.48
typing_extensions==4.15.0
Werkzeug==3.1.7
<title>Cadastro</title>
<h1>Nova Pessoa</h1>
<form method="POST">
Nome: <input type="text" name="nome" required /><br />
Sexo:
<select name="sexo">
<option>Masculino</option>
<option>Feminino</option></select
><br />
Nascimento: <input type="date" name="data_nascimento" required /><br />
Cidade: <input type="text" name="cidade" required /><br />
Telefone: <input type="tel" name="telefone" /><br />
<button type="submit">Salvar</button>
</form>
<title>Lista de Pessoas</title>
<h1>Pessoas Cadastradas</h1>
<a href="/cadastro"><button>Novo Cadastro</button></a>
<table border="1" style="margin-top: 10px">
<tr>
<th>Nome</th>
<th>Sexo</th>
<th>Data</th>
<th>Cidade</th>
<th>Telefone</th>
</tr>
{% for p in pessoas %}
<tr>
<td>{{ p.nome }}</td>
<td>{{ p.sexo }}</td>
<td>{{ p.data_nascimento }}</td>
<td>{{ p.cidade }}</td>
<td>{{ p.telefone or '' }}</td>
</tr>
{% endfor %}
</table>
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment