Pessoal, bom dia!
Venho evoluindo na programação em Python e encontrei o seguinte erro durante o meu curso de Flask avançado:
Observações: Costumo alterar nomes chaves dentro dos projetos para que não fiquem meramente no CTRL+C e CTRL+V. No meu caso não se trata de uma Jogoteca, e sim de um repositório de instrumentos. Segue evidêcia do erro em anexo.!
Código do programa: **
from flask import Flask, render_template, request, redirect, session, flash, url_for
from flask_sqlalchemy import SQLAlchemy
app = Flask(__name__)
app.secret_key = 'alura'
app.config['SQLALCHEMY_DATABASE_URI'] = \
'{SGBD}://{usuario}:{senha}@{servidor}/{database}'.format(
SGBD='mysql+mysqlconnector',
usuario='root',
senha='xxxx',
servidor='localhost',
database='volt_instrumentos'
)
db = SQLAlchemy(app)
class Maquinas(db.Model):
id = db.Column(db.Integer, primary_key=True, autoincrement=True)
tag = db.Column(db.String(20), nullable=False)
nome = db.Column(db.String(50), nullable=False)
temperatura = db.Column(db.String(5), nullable=False)
umidade = db.Column(db.String(10), nullable=False)
def __repr__(self):
return '<Name %r' % self.name
class Usuarios(db.Model):
nickname = db.Column(db.String(8), primary_key=True)
nome = db.Column(db.String(20), nullable=False)
senha = db.Column(db.String(100), nullable=False)
def __repr__(self):
return '<Name %r' % self.name
@app.route('/')
def index():
lista = Maquinas.query.order_by(Maquinas.id)
return render_template('listaInstrumentos.html', titulo='Instrumentos', maquinas=lista)
@app.route('/novo')
def novo():
if 'usuario_logado' not in session or session['usuario_logado'] == None:
return redirect(url_for('login', proxima=url_for('novo')))
return render_template('novoInstrumento.html', titulo='Novo instrumento')
@app.route('/criar', methods=['POST', ])
def criar():
tag = request.form['tag']
nome = request.form['nome']
temperatura = request.form['temperatura']
umidade = request.form['umidade']
maquina = Maquinas.query.filter_by(name=nome).first()
if maquina:
flash('Jogo já existente!')
return redirect(url_for('index'))
nova_maquina = Maquinas(tag=tag, nome=nome, temperatura=temperatura, umidade=umidade)
db.session.add(nova_maquina)
db.session.commit()
@app.route('/login')
def login():
proxima = request.args.get('proxima')
return render_template('login.html', titulo='Login', proxima=proxima)
@app.route('/autenticar', methods=['POST', ])
def autenticar():
usuarios = Usuarios.query.filter_by(nickname=request.form['usuario']).first()
if usuarios:
if request.form['senha'] == usuarios.senha:
session['usuario_logado'] = usuarios.nickname
flash(usuarios.nickname + ' logado com sucesso!')
proxima_pagina = request.form['proxima']
if proxima_pagina != 'None':
return redirect(proxima_pagina)
else:
flash('Falha no login')
return redirect(url_for('login'))
@app.route('/logout')
def logout():
session['usuario_logado'] = None
flash('Logout efetuado com sucesso')
return redirect(url_for('index'))
app.run(debug=True)
Código de criação da tabela no SQL
# criando tabelas
TABLES = {}
TABLES['Instrumentos'] = ('''
CREATE TABLE `instrumentos` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`tag` varchar(20) NOT NULL,
`nome` varchar(50) NOT NULL,
`temperatura` varchar(5) NOT NULL,
`umidade` varchar(10) NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;''')